From b32a1c3974ca0f1497880238f70392024ec4e3cf Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Sun, 14 Jul 2024 18:00:50 +0200 Subject: [PATCH 01/12] init ng new webapp --- webapp/.editorconfig | 16 + webapp/.gitignore | 42 + webapp/.vscode/extensions.json | 4 + webapp/.vscode/launch.json | 20 + webapp/.vscode/tasks.json | 42 + webapp/README.md | 27 + webapp/angular.json | 127 + webapp/package-lock.json | 13039 ++++++++++++++++ webapp/package.json | 38 + webapp/public/favicon.ico | Bin 0 -> 176916 bytes webapp/src/app/app.component.html | 336 + webapp/src/app/app.component.ts | 13 + webapp/src/app/app.config.ts | 8 + webapp/src/app/app.routes.ts | 3 + .../hello-world/hello-world.component.html | 1 + .../app/hello-world/hello-world.component.ts | 13 + webapp/src/index.html | 13 + webapp/src/main.ts | 6 + webapp/src/styles.sass | 1 + webapp/tsconfig.app.json | 15 + webapp/tsconfig.json | 32 + webapp/tsconfig.spec.json | 15 + 22 files changed, 13811 insertions(+) create mode 100644 webapp/.editorconfig create mode 100644 webapp/.gitignore create mode 100644 webapp/.vscode/extensions.json create mode 100644 webapp/.vscode/launch.json create mode 100644 webapp/.vscode/tasks.json create mode 100644 webapp/README.md create mode 100644 webapp/angular.json create mode 100644 webapp/package-lock.json create mode 100644 webapp/package.json create mode 100644 webapp/public/favicon.ico create mode 100644 webapp/src/app/app.component.html create mode 100644 webapp/src/app/app.component.ts create mode 100644 webapp/src/app/app.config.ts create mode 100644 webapp/src/app/app.routes.ts create mode 100644 webapp/src/app/hello-world/hello-world.component.html create mode 100644 webapp/src/app/hello-world/hello-world.component.ts create mode 100644 webapp/src/index.html create mode 100644 webapp/src/main.ts create mode 100644 webapp/src/styles.sass create mode 100644 webapp/tsconfig.app.json create mode 100644 webapp/tsconfig.json create mode 100644 webapp/tsconfig.spec.json diff --git a/webapp/.editorconfig b/webapp/.editorconfig new file mode 100644 index 00000000..59d9a3a3 --- /dev/null +++ b/webapp/.editorconfig @@ -0,0 +1,16 @@ +# Editor configuration, see https://editorconfig.org +root = true + +[*] +charset = utf-8 +indent_style = space +indent_size = 2 +insert_final_newline = true +trim_trailing_whitespace = true + +[*.ts] +quote_type = single + +[*.md] +max_line_length = off +trim_trailing_whitespace = false diff --git a/webapp/.gitignore b/webapp/.gitignore new file mode 100644 index 00000000..cc7b1413 --- /dev/null +++ b/webapp/.gitignore @@ -0,0 +1,42 @@ +# See https://docs.github.com/get-started/getting-started-with-git/ignoring-files for more about ignoring files. + +# Compiled output +/dist +/tmp +/out-tsc +/bazel-out + +# Node +/node_modules +npm-debug.log +yarn-error.log + +# IDEs and editors +.idea/ +.project +.classpath +.c9/ +*.launch +.settings/ +*.sublime-workspace + +# Visual Studio Code +.vscode/* +!.vscode/settings.json +!.vscode/tasks.json +!.vscode/launch.json +!.vscode/extensions.json +.history/* + +# Miscellaneous +/.angular/cache +.sass-cache/ +/connect.lock +/coverage +/libpeerconnection.log +testem.log +/typings + +# System files +.DS_Store +Thumbs.db diff --git a/webapp/.vscode/extensions.json b/webapp/.vscode/extensions.json new file mode 100644 index 00000000..77b37457 --- /dev/null +++ b/webapp/.vscode/extensions.json @@ -0,0 +1,4 @@ +{ + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=827846 + "recommendations": ["angular.ng-template"] +} diff --git a/webapp/.vscode/launch.json b/webapp/.vscode/launch.json new file mode 100644 index 00000000..925af837 --- /dev/null +++ b/webapp/.vscode/launch.json @@ -0,0 +1,20 @@ +{ + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 + "version": "0.2.0", + "configurations": [ + { + "name": "ng serve", + "type": "chrome", + "request": "launch", + "preLaunchTask": "npm: start", + "url": "http://localhost:4200/" + }, + { + "name": "ng test", + "type": "chrome", + "request": "launch", + "preLaunchTask": "npm: test", + "url": "http://localhost:9876/debug.html" + } + ] +} diff --git a/webapp/.vscode/tasks.json b/webapp/.vscode/tasks.json new file mode 100644 index 00000000..a298b5bd --- /dev/null +++ b/webapp/.vscode/tasks.json @@ -0,0 +1,42 @@ +{ + // For more information, visit: https://go.microsoft.com/fwlink/?LinkId=733558 + "version": "2.0.0", + "tasks": [ + { + "type": "npm", + "script": "start", + "isBackground": true, + "problemMatcher": { + "owner": "typescript", + "pattern": "$tsc", + "background": { + "activeOnStart": true, + "beginsPattern": { + "regexp": "(.*?)" + }, + "endsPattern": { + "regexp": "bundle generation complete" + } + } + } + }, + { + "type": "npm", + "script": "test", + "isBackground": true, + "problemMatcher": { + "owner": "typescript", + "pattern": "$tsc", + "background": { + "activeOnStart": true, + "beginsPattern": { + "regexp": "(.*?)" + }, + "endsPattern": { + "regexp": "bundle generation complete" + } + } + } + } + ] +} diff --git a/webapp/README.md b/webapp/README.md new file mode 100644 index 00000000..e9986851 --- /dev/null +++ b/webapp/README.md @@ -0,0 +1,27 @@ +# Webapp + +This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 18.1.0. + +## Development server + +Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The application will automatically reload if you change any of the source files. + +## Code scaffolding + +Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`. + +## Build + +Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory. + +## Running unit tests + +Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io). + +## Running end-to-end tests + +Run `ng e2e` to execute the end-to-end tests via a platform of your choice. To use this command, you need to first add a package that implements end-to-end testing capabilities. + +## Further help + +To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.dev/tools/cli) page. diff --git a/webapp/angular.json b/webapp/angular.json new file mode 100644 index 00000000..c44e2c1e --- /dev/null +++ b/webapp/angular.json @@ -0,0 +1,127 @@ +{ + "$schema": "./node_modules/@angular/cli/lib/config/schema.json", + "version": 1, + "newProjectRoot": "projects", + "projects": { + "webapp": { + "projectType": "application", + "schematics": { + "@schematics/angular:component": { + "inlineStyle": true, + "style": "sass", + "skipTests": true, + "standalone": true, + "changeDetection": "OnPush" + }, + "@schematics/angular:class": { + "skipTests": true + }, + "@schematics/angular:directive": { + "skipTests": true + }, + "@schematics/angular:guard": { + "skipTests": true + }, + "@schematics/angular:interceptor": { + "skipTests": true + }, + "@schematics/angular:pipe": { + "skipTests": true + }, + "@schematics/angular:resolver": { + "skipTests": true + }, + "@schematics/angular:service": { + "skipTests": true + } + }, + "root": "", + "sourceRoot": "src", + "prefix": "", + "architect": { + "build": { + "builder": "@angular-devkit/build-angular:application", + "options": { + "outputPath": "dist/webapp", + "index": "src/index.html", + "browser": "src/main.ts", + "polyfills": [ + "zone.js" + ], + "tsConfig": "tsconfig.app.json", + "inlineStyleLanguage": "sass", + "assets": [ + { + "glob": "**/*", + "input": "public" + } + ], + "styles": [ + "src/styles.sass" + ], + "scripts": [] + }, + "configurations": { + "production": { + "budgets": [ + { + "type": "initial", + "maximumWarning": "500kB", + "maximumError": "1MB" + }, + { + "type": "anyComponentStyle", + "maximumWarning": "2kB", + "maximumError": "4kB" + } + ], + "outputHashing": "all" + }, + "development": { + "optimization": false, + "extractLicenses": false, + "sourceMap": true + } + }, + "defaultConfiguration": "production" + }, + "serve": { + "builder": "@angular-devkit/build-angular:dev-server", + "configurations": { + "production": { + "buildTarget": "webapp:build:production" + }, + "development": { + "buildTarget": "webapp:build:development" + } + }, + "defaultConfiguration": "development" + }, + "extract-i18n": { + "builder": "@angular-devkit/build-angular:extract-i18n" + }, + "test": { + "builder": "@angular-devkit/build-angular:karma", + "options": { + "polyfills": [ + "zone.js", + "zone.js/testing" + ], + "tsConfig": "tsconfig.spec.json", + "inlineStyleLanguage": "sass", + "assets": [ + { + "glob": "**/*", + "input": "public" + } + ], + "styles": [ + "src/styles.sass" + ], + "scripts": [] + } + } + } + } + } +} diff --git a/webapp/package-lock.json b/webapp/package-lock.json new file mode 100644 index 00000000..42a8d9ea --- /dev/null +++ b/webapp/package-lock.json @@ -0,0 +1,13039 @@ +{ + "name": "webapp", + "version": "0.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "webapp", + "version": "0.0.0", + "dependencies": { + "@angular/animations": "^18.1.0", + "@angular/common": "^18.1.0", + "@angular/compiler": "^18.1.0", + "@angular/core": "^18.1.0", + "@angular/forms": "^18.1.0", + "@angular/platform-browser": "^18.1.0", + "@angular/platform-browser-dynamic": "^18.1.0", + "@angular/router": "^18.1.0", + "rxjs": "~7.8.0", + "tslib": "^2.3.0", + "zone.js": "~0.14.3" + }, + "devDependencies": { + "@angular-devkit/build-angular": "^18.1.0", + "@angular/cli": "^18.1.0", + "@angular/compiler-cli": "^18.1.0", + "@types/jasmine": "~5.1.0", + "jasmine-core": "~5.1.0", + "karma": "~6.4.0", + "karma-chrome-launcher": "~3.2.0", + "karma-coverage": "~2.2.0", + "karma-jasmine": "~5.1.0", + "karma-jasmine-html-reporter": "~2.1.0", + "typescript": "~5.5.2" + } + }, + "node_modules/@ampproject/remapping": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@angular-devkit/architect": { + "version": "0.1801.0", + "resolved": "https://registry.npmjs.org/@angular-devkit/architect/-/architect-0.1801.0.tgz", + "integrity": "sha512-iZa3J3CrZT6MKiHPw8ijgVwMyCMewCsP4xc75SetUwF/yuqRUHygALs5jJVZQFQjSFUrkg9gqXa1cCjFDwpT8A==", + "dev": true, + "dependencies": { + "@angular-devkit/core": "18.1.0", + "rxjs": "7.8.1" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + } + }, + "node_modules/@angular-devkit/build-angular": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular-devkit/build-angular/-/build-angular-18.1.0.tgz", + "integrity": "sha512-j/YrEFuEX90Pcyzjew6EcCoxT+Va0AlGjgWyVIuStNTEsCx9Vp7T2tS7w6LL1t6leM7gzf8f/ZKtvRPnAsWdQg==", + "dev": true, + "dependencies": { + "@ampproject/remapping": "2.3.0", + "@angular-devkit/architect": "0.1801.0", + "@angular-devkit/build-webpack": "0.1801.0", + "@angular-devkit/core": "18.1.0", + "@angular/build": "18.1.0", + "@babel/core": "7.24.7", + "@babel/generator": "7.24.7", + "@babel/helper-annotate-as-pure": "7.24.7", + "@babel/helper-split-export-declaration": "7.24.7", + "@babel/plugin-transform-async-generator-functions": "7.24.7", + "@babel/plugin-transform-async-to-generator": "7.24.7", + "@babel/plugin-transform-runtime": "7.24.7", + "@babel/preset-env": "7.24.7", + "@babel/runtime": "7.24.7", + "@discoveryjs/json-ext": "0.5.7", + "@ngtools/webpack": "18.1.0", + "@vitejs/plugin-basic-ssl": "1.1.0", + "ansi-colors": "4.1.3", + "autoprefixer": "10.4.19", + "babel-loader": "9.1.3", + "browserslist": "^4.21.5", + "copy-webpack-plugin": "12.0.2", + "critters": "0.0.24", + "css-loader": "7.1.2", + "esbuild-wasm": "0.21.5", + "fast-glob": "3.3.2", + "http-proxy-middleware": "3.0.0", + "https-proxy-agent": "7.0.5", + "istanbul-lib-instrument": "6.0.2", + "jsonc-parser": "3.3.1", + "karma-source-map-support": "1.4.0", + "less": "4.2.0", + "less-loader": "12.2.0", + "license-webpack-plugin": "4.0.2", + "loader-utils": "3.3.1", + "magic-string": "0.30.10", + "mini-css-extract-plugin": "2.9.0", + "mrmime": "2.0.0", + "open": "10.1.0", + "ora": "5.4.1", + "parse5-html-rewriting-stream": "7.0.0", + "picomatch": "4.0.2", + "piscina": "4.6.1", + "postcss": "8.4.38", + "postcss-loader": "8.1.1", + "resolve-url-loader": "5.0.0", + "rxjs": "7.8.1", + "sass": "1.77.6", + "sass-loader": "14.2.1", + "semver": "7.6.2", + "source-map-loader": "5.0.0", + "source-map-support": "0.5.21", + "terser": "5.29.2", + "tree-kill": "1.2.2", + "tslib": "2.6.3", + "undici": "6.19.2", + "vite": "5.3.2", + "watchpack": "2.4.1", + "webpack": "5.92.1", + "webpack-dev-middleware": "7.2.1", + "webpack-dev-server": "5.0.4", + "webpack-merge": "5.10.0", + "webpack-subresource-integrity": "5.1.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + }, + "optionalDependencies": { + "esbuild": "0.21.5" + }, + "peerDependencies": { + "@angular/compiler-cli": "^18.0.0", + "@angular/localize": "^18.0.0", + "@angular/platform-server": "^18.0.0", + "@angular/service-worker": "^18.0.0", + "@web/test-runner": "^0.18.0", + "browser-sync": "^3.0.2", + "jest": "^29.5.0", + "jest-environment-jsdom": "^29.5.0", + "karma": "^6.3.0", + "ng-packagr": "^18.0.0", + "protractor": "^7.0.0", + "tailwindcss": "^2.0.0 || ^3.0.0", + "typescript": ">=5.4 <5.6" + }, + "peerDependenciesMeta": { + "@angular/localize": { + "optional": true + }, + "@angular/platform-server": { + "optional": true + }, + "@angular/service-worker": { + "optional": true + }, + "@web/test-runner": { + "optional": true + }, + "browser-sync": { + "optional": true + }, + "jest": { + "optional": true + }, + "jest-environment-jsdom": { + "optional": true + }, + "karma": { + "optional": true + }, + "ng-packagr": { + "optional": true + }, + "protractor": { + "optional": true + }, + "tailwindcss": { + "optional": true + } + } + }, + "node_modules/@angular-devkit/build-webpack": { + "version": "0.1801.0", + "resolved": "https://registry.npmjs.org/@angular-devkit/build-webpack/-/build-webpack-0.1801.0.tgz", + "integrity": "sha512-EnkkhE4tVOk3lU5/bt8hNCQCJMefcpU5E4jChRmFu+m0OtKK2kax3hjPTUVwcpbjwpG5rO7J/U5yIhCY9afXKw==", + "dev": true, + "dependencies": { + "@angular-devkit/architect": "0.1801.0", + "rxjs": "7.8.1" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + }, + "peerDependencies": { + "webpack": "^5.30.0", + "webpack-dev-server": "^5.0.2" + } + }, + "node_modules/@angular-devkit/core": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular-devkit/core/-/core-18.1.0.tgz", + "integrity": "sha512-6eXQDzHZCbpSMLv9Ohl+1QyLVDmGEXpuuHz3y64LfUTP0aEiBaxk96FjLXIxzJ4f2pbbW2XHzc+yuboGToRA0w==", + "dev": true, + "dependencies": { + "ajv": "8.16.0", + "ajv-formats": "3.0.1", + "jsonc-parser": "3.3.1", + "picomatch": "4.0.2", + "rxjs": "7.8.1", + "source-map": "0.7.4" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + }, + "peerDependencies": { + "chokidar": "^3.5.2" + }, + "peerDependenciesMeta": { + "chokidar": { + "optional": true + } + } + }, + "node_modules/@angular-devkit/schematics": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular-devkit/schematics/-/schematics-18.1.0.tgz", + "integrity": "sha512-BjrYutLfYFiPOSEcLBWCj3ENkwDn8gMfBSJesaBz7OrZBZGK5j0dVgBLIsGTP96TKo4o4vszJQOvS4AtV6xMGg==", + "dev": true, + "dependencies": { + "@angular-devkit/core": "18.1.0", + "jsonc-parser": "3.3.1", + "magic-string": "0.30.10", + "ora": "5.4.1", + "rxjs": "7.8.1" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + } + }, + "node_modules/@angular/animations": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/animations/-/animations-18.1.0.tgz", + "integrity": "sha512-K0BhvZ/SIVoGXZVuh1KOJDdgcGlHfFGMGrs58utndndAb+gYXReMfz4GR5cQs2OObH6TKmIOY2EH7Og1CY2tsw==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/core": "18.1.0" + } + }, + "node_modules/@angular/build": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/build/-/build-18.1.0.tgz", + "integrity": "sha512-4yLrGqMDoNBis2Z4s8F3wSqlB2XLtwy/10tREBk9xVaCojERiwDvtHqzbMeHqD6ZMGDFtdhI12q8FT5jZVUmAw==", + "dev": true, + "dependencies": { + "@ampproject/remapping": "2.3.0", + "@angular-devkit/architect": "0.1801.0", + "@babel/core": "7.24.7", + "@babel/helper-annotate-as-pure": "7.24.7", + "@babel/helper-split-export-declaration": "7.24.7", + "@babel/plugin-syntax-import-attributes": "7.24.7", + "@inquirer/confirm": "3.1.11", + "@vitejs/plugin-basic-ssl": "1.1.0", + "ansi-colors": "4.1.3", + "browserslist": "^4.23.0", + "critters": "0.0.24", + "esbuild": "0.21.5", + "fast-glob": "3.3.2", + "https-proxy-agent": "7.0.5", + "lmdb": "3.0.12", + "magic-string": "0.30.10", + "mrmime": "2.0.0", + "ora": "5.4.1", + "parse5-html-rewriting-stream": "7.0.0", + "picomatch": "4.0.2", + "piscina": "4.6.1", + "rollup": "4.18.0", + "sass": "1.77.6", + "semver": "7.6.2", + "undici": "6.19.2", + "vite": "5.3.2", + "watchpack": "2.4.1" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + }, + "peerDependencies": { + "@angular/compiler-cli": "^18.0.0", + "@angular/localize": "^18.0.0", + "@angular/platform-server": "^18.0.0", + "@angular/service-worker": "^18.0.0", + "less": "^4.2.0", + "postcss": "^8.4.0", + "tailwindcss": "^2.0.0 || ^3.0.0", + "typescript": ">=5.4 <5.6" + }, + "peerDependenciesMeta": { + "@angular/localize": { + "optional": true + }, + "@angular/platform-server": { + "optional": true + }, + "@angular/service-worker": { + "optional": true + }, + "less": { + "optional": true + }, + "postcss": { + "optional": true + }, + "tailwindcss": { + "optional": true + } + } + }, + "node_modules/@angular/cli": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-18.1.0.tgz", + "integrity": "sha512-2E+b7S/736AOmxf5je9OWoPpgPY240TfJfFXwQiVvq/4KyC+ZR9lBrqRx72Xghn8nu3z8Q2BPZIXVGZppl0USQ==", + "dev": true, + "dependencies": { + "@angular-devkit/architect": "0.1801.0", + "@angular-devkit/core": "18.1.0", + "@angular-devkit/schematics": "18.1.0", + "@inquirer/prompts": "5.0.7", + "@listr2/prompt-adapter-inquirer": "2.0.13", + "@schematics/angular": "18.1.0", + "@yarnpkg/lockfile": "1.1.0", + "ini": "4.1.3", + "jsonc-parser": "3.3.1", + "listr2": "8.2.3", + "npm-package-arg": "11.0.2", + "npm-pick-manifest": "9.0.1", + "pacote": "18.0.6", + "resolve": "1.22.8", + "semver": "7.6.2", + "symbol-observable": "4.0.0", + "yargs": "17.7.2" + }, + "bin": { + "ng": "bin/ng.js" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + } + }, + "node_modules/@angular/common": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/common/-/common-18.1.0.tgz", + "integrity": "sha512-noHDLarQSCZZh7hyNd0HR61Fut+q4QCVq9qc/jKPglfbV/6nPujQSmSpT+rNJlNuBOrCLuvH/CNBNbiqii+x3g==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/core": "18.1.0", + "rxjs": "^6.5.3 || ^7.4.0" + } + }, + "node_modules/@angular/compiler": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/compiler/-/compiler-18.1.0.tgz", + "integrity": "sha512-JRQzVTeJGSfRLY+dx+gwu/hPQVB8K+5pW12Z42M9x/HBgGW4in0cO2zHkeQPvImqm0nak82Us1Hyf5C+qTlMMQ==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/core": "18.1.0" + }, + "peerDependenciesMeta": { + "@angular/core": { + "optional": true + } + } + }, + "node_modules/@angular/compiler-cli": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/compiler-cli/-/compiler-cli-18.1.0.tgz", + "integrity": "sha512-BBsogLPJwxkPh7f8RVHsxyyqNE8XpHbAanjB5fAwnU4W6Sw1kR5rFzkeZM3xaRm2MDiC8DovIl6hlf+s/mKYOw==", + "dev": true, + "dependencies": { + "@babel/core": "7.24.7", + "@jridgewell/sourcemap-codec": "^1.4.14", + "chokidar": "^3.0.0", + "convert-source-map": "^1.5.1", + "reflect-metadata": "^0.2.0", + "semver": "^7.0.0", + "tslib": "^2.3.0", + "yargs": "^17.2.1" + }, + "bin": { + "ng-xi18n": "bundles/src/bin/ng_xi18n.js", + "ngc": "bundles/src/bin/ngc.js", + "ngcc": "bundles/ngcc/index.js" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/compiler": "18.1.0", + "typescript": ">=5.4 <5.6" + } + }, + "node_modules/@angular/core": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/core/-/core-18.1.0.tgz", + "integrity": "sha512-/57/s7CD/0CwlN+3FlhVmx7ypCWXjKi5UKtnlBAUg0D1denIf6ADxwTHFZABYZcYBqOTJgeQUtUw9u/A+0CIlg==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "rxjs": "^6.5.3 || ^7.4.0", + "zone.js": "~0.14.0" + } + }, + "node_modules/@angular/forms": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/forms/-/forms-18.1.0.tgz", + "integrity": "sha512-m+7m9wa+n5dEacd458eSZsZTz0B+HbOtr7/uqM0YTMQaPrhwl1epG5Y103mB6yr00JiJcLNlPLjP888cHFjldQ==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/common": "18.1.0", + "@angular/core": "18.1.0", + "@angular/platform-browser": "18.1.0", + "rxjs": "^6.5.3 || ^7.4.0" + } + }, + "node_modules/@angular/platform-browser": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/platform-browser/-/platform-browser-18.1.0.tgz", + "integrity": "sha512-jCmxthiI4Zef54crckNht60xwfIsuciGeyZvb7SsXna2maLW9fA4uz1VhZqIWTiBnHwNynVlyfBX3/jBD7S9+g==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/animations": "18.1.0", + "@angular/common": "18.1.0", + "@angular/core": "18.1.0" + }, + "peerDependenciesMeta": { + "@angular/animations": { + "optional": true + } + } + }, + "node_modules/@angular/platform-browser-dynamic": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/platform-browser-dynamic/-/platform-browser-dynamic-18.1.0.tgz", + "integrity": "sha512-D/wuOQf+gULld9DVEzn2Lw3WbTyAYf/sp3DC5k83O+DQsG3eAIsVkt0zdE+U3DrDYsiWg8M3X+ioi3ouqK0mNg==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/common": "18.1.0", + "@angular/compiler": "18.1.0", + "@angular/core": "18.1.0", + "@angular/platform-browser": "18.1.0" + } + }, + "node_modules/@angular/router": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@angular/router/-/router-18.1.0.tgz", + "integrity": "sha512-dl2cSxZkl4we+rWMxdm123TZzlor6yxwNFI2yT7b6DP2i+rXaaHBSSPet0ASp+UX6djz+Osr56Bifs6wi4rhiQ==", + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/common": "18.1.0", + "@angular/core": "18.1.0", + "@angular/platform-browser": "18.1.0", + "rxjs": "^6.5.3 || ^7.4.0" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz", + "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.24.7", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/compat-data": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.24.8.tgz", + "integrity": "sha512-c4IM7OTg6k1Q+AJ153e2mc2QVTezTwnb4VzquwcyiEzGnW0Kedv4do/TrkU98qPeC5LNiMt/QXwIjzYXLBpyZg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/core": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.7.tgz", + "integrity": "sha512-nykK+LEK86ahTkX/3TgauT0ikKoNCfKHEaZYTUVupJdTLzGNvrblu4u6fa7DhZONAltdf8e662t/abY8idrd/g==", + "dev": true, + "dependencies": { + "@ampproject/remapping": "^2.2.0", + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.24.7", + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helpers": "^7.24.7", + "@babel/parser": "^7.24.7", + "@babel/template": "^7.24.7", + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7", + "convert-source-map": "^2.0.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.2.3", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/babel" + } + }, + "node_modules/@babel/core/node_modules/convert-source-map": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", + "dev": true + }, + "node_modules/@babel/core/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/generator": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.24.7.tgz", + "integrity": "sha512-oipXieGC3i45Y1A41t4tAqpnEZWgB/lC6Ehh6+rOviR5XWpTtMmLN+fGjz9vOiNRt0p6RtO6DtD0pdU3vpqdSA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.24.7", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", + "jsesc": "^2.5.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-annotate-as-pure": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.24.7.tgz", + "integrity": "sha512-BaDeOonYvhdKw+JoMVkAixAAJzG2jVPIwWoKBPdYuY9b452e2rPuI9QPYh3KpofZ3pW2akOmwZLOiOsHMiqRAg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.24.7.tgz", + "integrity": "sha512-xZeCVVdwb4MsDBkkyZ64tReWYrLRHlMN72vP7Bdm3OUOuyFZExhsHUUnuWnm2/XOlAJzR0LfPpB56WXZn0X/lA==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.24.8.tgz", + "integrity": "sha512-oU+UoqCHdp+nWVDkpldqIQL/i/bvAv53tRqLG/s+cOXxe66zOYLU7ar/Xs3LdmBihrUMEUhwu6dMZwbNOYDwvw==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.24.8", + "@babel/helper-validator-option": "^7.24.8", + "browserslist": "^4.23.1", + "lru-cache": "^5.1.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/helper-create-class-features-plugin": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.8.tgz", + "integrity": "sha512-4f6Oqnmyp2PP3olgUMmOwC3akxSm5aBYraQ6YDdKy7NcAMkDECHWG0DEnV6M2UAkERgIBhYt8S27rURPg7SxWA==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-member-expression-to-functions": "^7.24.8", + "@babel/helper-optimise-call-expression": "^7.24.7", + "@babel/helper-replace-supers": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-create-class-features-plugin/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/helper-create-regexp-features-plugin": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.24.7.tgz", + "integrity": "sha512-03TCmXy2FtXJEZfbXDTSqq1fRJArk7lX9DOFC/47VthYcxyIOx+eXQmdo6DOQvrbpIix+KfXwvuXdFDZHxt+rA==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.24.7", + "regexpu-core": "^5.3.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-create-regexp-features-plugin/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/helper-define-polyfill-provider": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.6.2.tgz", + "integrity": "sha512-LV76g+C502biUK6AyZ3LK10vDpDyCzZnhZFXkH1L75zHPj68+qc8Zfpx2th+gzwA2MzyK+1g/3EPl62yFnVttQ==", + "dev": true, + "dependencies": { + "@babel/helper-compilation-targets": "^7.22.6", + "@babel/helper-plugin-utils": "^7.22.5", + "debug": "^4.1.1", + "lodash.debounce": "^4.0.8", + "resolve": "^1.14.2" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/@babel/helper-environment-visitor": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.24.7.tgz", + "integrity": "sha512-DoiN84+4Gnd0ncbBOM9AZENV4a5ZiL39HYMyZJGZ/AZEykHYdJw0wW3kdcsh9/Kn+BRXHLkkklZ51ecPKmI1CQ==", + "dev": true, + "dependencies": { + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-function-name": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.24.7.tgz", + "integrity": "sha512-FyoJTsj/PEUWu1/TYRiXTIHc8lbw+TDYkZuoE43opPS5TrI7MyONBE1oNvfguEXAD9yhQRrVBnXdXzSLQl9XnA==", + "dev": true, + "dependencies": { + "@babel/template": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-hoist-variables": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.24.7.tgz", + "integrity": "sha512-MJJwhkoGy5c4ehfoRyrJ/owKeMl19U54h27YYftT0o2teQ3FJ3nQUf/I3LlJsX4l3qlw7WRXUmiyajvHXoTubQ==", + "dev": true, + "dependencies": { + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-member-expression-to-functions": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.24.8.tgz", + "integrity": "sha512-LABppdt+Lp/RlBxqrh4qgf1oEH/WxdzQNDJIu5gC/W1GyvPVrOBiItmmM8wan2fm4oYqFuFfkXmlGpLQhPY8CA==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.24.8", + "@babel/types": "^7.24.8" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-imports": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz", + "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-transforms": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.24.8.tgz", + "integrity": "sha512-m4vWKVqvkVAWLXfHCCfff2luJj86U+J0/x+0N3ArG/tP0Fq7zky2dYwMbtPmkc/oulkkbjdL3uWzuoBwQ8R00Q==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-simple-access": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-optimise-call-expression": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.24.7.tgz", + "integrity": "sha512-jKiTsW2xmWwxT1ixIdfXUZp+P5yURx2suzLZr5Hi64rURpDYdMW0pv+Uf17EYk2Rd428Lx4tLsnjGJzYKDM/6A==", + "dev": true, + "dependencies": { + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.8.tgz", + "integrity": "sha512-FFWx5142D8h2Mgr/iPVGH5G7w6jDn4jUSpZTyDnQO0Yn7Ks2Kuz6Pci8H6MPCoUJegd/UZQ3tAvfLCxQSnWWwg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-remap-async-to-generator": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.24.7.tgz", + "integrity": "sha512-9pKLcTlZ92hNZMQfGCHImUpDOlAgkkpqalWEeftW5FBya75k8Li2ilerxkM/uBEj01iBZXcCIB/bwvDYgWyibA==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-wrap-function": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-replace-supers": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.24.7.tgz", + "integrity": "sha512-qTAxxBM81VEyoAY0TtLrx1oAEJc09ZK67Q9ljQToqCnA+55eNwCORaxlKyu+rNfX86o8OXRUSNUnrtsAZXM9sg==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-member-expression-to-functions": "^7.24.7", + "@babel/helper-optimise-call-expression": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-simple-access": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz", + "integrity": "sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-skip-transparent-expression-wrappers": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.24.7.tgz", + "integrity": "sha512-IO+DLT3LQUElMbpzlatRASEyQtfhSE0+m465v++3jyyXeBTBUjtVZg28/gHeV5mrTJqvEKhKroBGAvhW+qPHiQ==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-split-export-declaration": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.24.7.tgz", + "integrity": "sha512-oy5V7pD+UvfkEATUKvIjvIAH/xCzfsFVw7ygW2SI6NClZzquT+mwdTfgfdbUiceh6iQO0CHtCPsyze/MZ2YbAA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-string-parser": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.8.tgz", + "integrity": "sha512-pO9KhhRcuUyGnJWwyEgnRJTSIZHiT+vMD0kPeD+so0l7mxkMT19g3pjY9GTnHySck/hDzq+dtW/4VgnMkippsQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz", + "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-option": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.8.tgz", + "integrity": "sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-wrap-function": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.24.7.tgz", + "integrity": "sha512-N9JIYk3TD+1vq/wn77YnJOqMtfWhNewNE+DJV4puD2X7Ew9J4JvrzrFDfTfyv5EgEXVy9/Wt8QiOErzEmv5Ifw==", + "dev": true, + "dependencies": { + "@babel/helper-function-name": "^7.24.7", + "@babel/template": "^7.24.7", + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helpers": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.8.tgz", + "integrity": "sha512-gV2265Nkcz7weJJfvDoAEVzC1e2OTDpkGbEsebse8koXUJUXPsCMi7sRo/+SPMuMZ9MtUPnGwITTnQnU5YjyaQ==", + "dev": true, + "dependencies": { + "@babel/template": "^7.24.7", + "@babel/types": "^7.24.8" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz", + "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.24.7", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/parser": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.8.tgz", + "integrity": "sha512-WzfbgXOkGzZiXXCqk43kKwZjzwx4oulxZi3nq2TYL9mOjQv6kYwul9mz6ID36njuL7Xkp6nJEfok848Zj10j/w==", + "dev": true, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/plugin-bugfix-firefox-class-in-computed-class-key": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-firefox-class-in-computed-class-key/-/plugin-bugfix-firefox-class-in-computed-class-key-7.24.7.tgz", + "integrity": "sha512-TiT1ss81W80eQsN+722OaeQMY/G4yTb4G9JrqeiDADs3N8lbPMGldWi9x8tyqCW5NLx1Jh2AvkE6r6QvEltMMQ==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.24.7.tgz", + "integrity": "sha512-unaQgZ/iRu/By6tsjMZzpeBZjChYfLYry6HrEXPoz3KmfF0sVBQ1l8zKMQ4xRGLWVsjuvB8nQfjNP/DcfEOCsg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.24.7.tgz", + "integrity": "sha512-+izXIbke1T33mY4MSNnrqhPXDz01WYhEf3yF5NbnUtkiNnm+XBZJl3kNfoK6NKmYlz/D07+l2GWVK/QfDkNCuQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7", + "@babel/plugin-transform-optional-chaining": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.13.0" + } + }, + "node_modules/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.24.7.tgz", + "integrity": "sha512-utA4HuR6F4Vvcr+o4DnjL8fCOlgRFGbeeBEGNg3ZTrLFw6VWG5XmUrvcQ0FjIYMU2ST4XcR2Wsp7t9qOAPnxMg==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-proposal-private-property-in-object": { + "version": "7.21.0-placeholder-for-preset-env.2", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.21.0-placeholder-for-preset-env.2.tgz", + "integrity": "sha512-SOSkfJDddaM7mak6cPEpswyTRnuRltl429hMraQEglW+OkovnCzsiszTmsrlY//qLFjCpQDFRvjdm2wA5pPm9w==", + "dev": true, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.12.13" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-dynamic-import": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", + "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-export-namespace-from": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", + "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.3" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-assertions": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.24.7.tgz", + "integrity": "sha512-Ec3NRUMoi8gskrkBe3fNmEQfxDvY8bgfQpz6jlk/41kX9eUjvpyqWU7PBP/pLAvMaSQjbMNKJmvX57jP+M6bPg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-attributes": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.24.7.tgz", + "integrity": "sha512-hbX+lKKeUMGihnK8nvKqmXBInriT3GVjzXKFriV3YC6APGxMbP8RZNFwy91+hocLXq90Mta+HshoB31802bb8A==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-meta": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", + "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-unicode-sets-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-unicode-sets-regex/-/plugin-syntax-unicode-sets-regex-7.18.6.tgz", + "integrity": "sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-transform-arrow-functions": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.24.7.tgz", + "integrity": "sha512-Dt9LQs6iEY++gXUwY03DNFat5C2NbO48jj+j/bSAz6b3HgPs39qcPiYt77fDObIcFwj3/C2ICX9YMwGflUoSHQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-async-generator-functions": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.24.7.tgz", + "integrity": "sha512-o+iF77e3u7ZS4AoAuJvapz9Fm001PuD2V3Lp6OSE4FYQke+cSewYtnek+THqGRWyQloRCyvWL1OkyfNEl9vr/g==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-remap-async-to-generator": "^7.24.7", + "@babel/plugin-syntax-async-generators": "^7.8.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-async-to-generator": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.24.7.tgz", + "integrity": "sha512-SQY01PcJfmQ+4Ash7NE+rpbLFbmqA2GPIgqzxfFTL4t1FKRq4zTms/7htKpoCUI9OcFYgzqfmCdH53s6/jn5fA==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-remap-async-to-generator": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-block-scoped-functions": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.24.7.tgz", + "integrity": "sha512-yO7RAz6EsVQDaBH18IDJcMB1HnrUn2FJ/Jslc/WtPPWcjhpUJXU/rjbwmluzp7v/ZzWcEhTMXELnnsz8djWDwQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-block-scoping": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.24.7.tgz", + "integrity": "sha512-Nd5CvgMbWc+oWzBsuaMcbwjJWAcp5qzrbg69SZdHSP7AMY0AbWFqFO0WTFCA1jxhMCwodRwvRec8k0QUbZk7RQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-class-properties": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-properties/-/plugin-transform-class-properties-7.24.7.tgz", + "integrity": "sha512-vKbfawVYayKcSeSR5YYzzyXvsDFWU2mD8U5TFeXtbCPLFUqe7GyCgvO6XDHzje862ODrOwy6WCPmKeWHbCFJ4w==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-class-static-block": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.24.7.tgz", + "integrity": "sha512-HMXK3WbBPpZQufbMG4B46A90PkuuhN9vBCb5T8+VAHqvAqvcLi+2cKoukcpmUYkszLhScU3l1iudhrks3DggRQ==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-class-static-block": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.12.0" + } + }, + "node_modules/@babel/plugin-transform-classes": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.24.8.tgz", + "integrity": "sha512-VXy91c47uujj758ud9wx+OMgheXm4qJfyhj1P18YvlrQkNOSrwsteHk+EFS3OMGfhMhpZa0A+81eE7G4QC+3CA==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-compilation-targets": "^7.24.8", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.8", + "@babel/helper-replace-supers": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-computed-properties": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.24.7.tgz", + "integrity": "sha512-25cS7v+707Gu6Ds2oY6tCkUwsJ9YIDbggd9+cu9jzzDgiNq7hR/8dkzxWfKWnTic26vsI3EsCXNd4iEB6e8esQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/template": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-destructuring": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.24.8.tgz", + "integrity": "sha512-36e87mfY8TnRxc7yc6M9g9gOB7rKgSahqkIKwLpz4Ppk2+zC2Cy1is0uwtuSG6AE4zlTOUa+7JGz9jCJGLqQFQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.8" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-dotall-regex": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.24.7.tgz", + "integrity": "sha512-ZOA3W+1RRTSWvyqcMJDLqbchh7U4NRGqwRfFSVbOLS/ePIP4vHB5e8T8eXcuqyN1QkgKyj5wuW0lcS85v4CrSw==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-duplicate-keys": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.24.7.tgz", + "integrity": "sha512-JdYfXyCRihAe46jUIliuL2/s0x0wObgwwiGxw/UbgJBr20gQBThrokO4nYKgWkD7uBaqM7+9x5TU7NkExZJyzw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-dynamic-import": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.24.7.tgz", + "integrity": "sha512-sc3X26PhZQDb3JhORmakcbvkeInvxz+A8oda99lj7J60QRuPZvNAk9wQlTBS1ZynelDrDmTU4pw1tyc5d5ZMUg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-dynamic-import": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-exponentiation-operator": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.24.7.tgz", + "integrity": "sha512-Rqe/vSc9OYgDajNIK35u7ot+KeCoetqQYFXM4Epf7M7ez3lWlOjrDjrwMei6caCVhfdw+mIKD4cgdGNy5JQotQ==", + "dev": true, + "dependencies": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-export-namespace-from": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.24.7.tgz", + "integrity": "sha512-v0K9uNYsPL3oXZ/7F9NNIbAj2jv1whUEtyA6aujhekLs56R++JDQuzRcP2/z4WX5Vg/c5lE9uWZA0/iUoFhLTA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-for-of": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.24.7.tgz", + "integrity": "sha512-wo9ogrDG1ITTTBsy46oGiN1dS9A7MROBTcYsfS8DtsImMkHk9JXJ3EWQM6X2SUw4x80uGPlwj0o00Uoc6nEE3g==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-function-name": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.24.7.tgz", + "integrity": "sha512-U9FcnA821YoILngSmYkW6FjyQe2TyZD5pHt4EVIhmcTkrJw/3KqcrRSxuOo5tFZJi7TE19iDyI1u+weTI7bn2w==", + "dev": true, + "dependencies": { + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-json-strings": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.24.7.tgz", + "integrity": "sha512-2yFnBGDvRuxAaE/f0vfBKvtnvvqU8tGpMHqMNpTN2oWMKIR3NqFkjaAgGwawhqK/pIN2T3XdjGPdaG0vDhOBGw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-json-strings": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-literals": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.24.7.tgz", + "integrity": "sha512-vcwCbb4HDH+hWi8Pqenwnjy+UiklO4Kt1vfspcQYFhJdpthSnW8XvWGyDZWKNVrVbVViI/S7K9PDJZiUmP2fYQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-logical-assignment-operators": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.24.7.tgz", + "integrity": "sha512-4D2tpwlQ1odXmTEIFWy9ELJcZHqrStlzK/dAOWYyxX3zT0iXQB6banjgeOJQXzEc4S0E0a5A+hahxPaEFYftsw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-member-expression-literals": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.24.7.tgz", + "integrity": "sha512-T/hRC1uqrzXMKLQ6UCwMT85S3EvqaBXDGf0FaMf4446Qx9vKwlghvee0+uuZcDUCZU5RuNi4781UQ7R308zzBw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-amd": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.24.7.tgz", + "integrity": "sha512-9+pB1qxV3vs/8Hdmz/CulFB8w2tuu6EB94JZFsjdqxQokwGa9Unap7Bo2gGBGIvPmDIVvQrom7r5m/TCDMURhg==", + "dev": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-commonjs": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.24.8.tgz", + "integrity": "sha512-WHsk9H8XxRs3JXKWFiqtQebdh9b/pTk4EgueygFzYlTKAg0Ud985mSevdNjdXdFBATSKVJGQXP1tv6aGbssLKA==", + "dev": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.24.8", + "@babel/helper-plugin-utils": "^7.24.8", + "@babel/helper-simple-access": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-systemjs": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.24.7.tgz", + "integrity": "sha512-GYQE0tW7YoaN13qFh3O1NCY4MPkUiAH3fiF7UcV/I3ajmDKEdG3l+UOcbAm4zUE3gnvUU+Eni7XrVKo9eO9auw==", + "dev": true, + "dependencies": { + "@babel/helper-hoist-variables": "^7.24.7", + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-umd": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.24.7.tgz", + "integrity": "sha512-3aytQvqJ/h9z4g8AsKPLvD4Zqi2qT+L3j7XoFFu1XBlZWEl2/1kWnhmAbxpLgPrHSY0M6UA02jyTiwUVtiKR6A==", + "dev": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.24.7.tgz", + "integrity": "sha512-/jr7h/EWeJtk1U/uz2jlsCioHkZk1JJZVcc8oQsJ1dUlaJD83f4/6Zeh2aHt9BIFokHIsSeDfhUmju0+1GPd6g==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-transform-new-target": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.24.7.tgz", + "integrity": "sha512-RNKwfRIXg4Ls/8mMTza5oPF5RkOW8Wy/WgMAp1/F1yZ8mMbtwXW+HDoJiOsagWrAhI5f57Vncrmr9XeT4CVapA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-nullish-coalescing-operator": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.24.7.tgz", + "integrity": "sha512-Ts7xQVk1OEocqzm8rHMXHlxvsfZ0cEF2yomUqpKENHWMF4zKk175Y4q8H5knJes6PgYad50uuRmt3UJuhBw8pQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-numeric-separator": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.24.7.tgz", + "integrity": "sha512-e6q1TiVUzvH9KRvicuxdBTUj4AdKSRwzIyFFnfnezpCfP2/7Qmbb8qbU2j7GODbl4JMkblitCQjKYUaX/qkkwA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-numeric-separator": "^7.10.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-object-rest-spread": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.24.7.tgz", + "integrity": "sha512-4QrHAr0aXQCEFni2q4DqKLD31n2DL+RxcwnNjDFkSG0eNQ/xCavnRkfCUjsyqGC2OviNJvZOF/mQqZBw7i2C5Q==", + "dev": true, + "dependencies": { + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-transform-parameters": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-object-super": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.24.7.tgz", + "integrity": "sha512-A/vVLwN6lBrMFmMDmPPz0jnE6ZGx7Jq7d6sT/Ev4H65RER6pZ+kczlf1DthF5N0qaPHBsI7UXiE8Zy66nmAovg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-replace-supers": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-optional-catch-binding": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.24.7.tgz", + "integrity": "sha512-uLEndKqP5BfBbC/5jTwPxLh9kqPWWgzN/f8w6UwAIirAEqiIVJWWY312X72Eub09g5KF9+Zn7+hT7sDxmhRuKA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-optional-chaining": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.24.8.tgz", + "integrity": "sha512-5cTOLSMs9eypEy8JUVvIKOu6NgvbJMnpG62VpIHrTmROdQ+L5mDAaI40g25k5vXti55JWNX5jCkq3HZxXBQANw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.8", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7", + "@babel/plugin-syntax-optional-chaining": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-parameters": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.24.7.tgz", + "integrity": "sha512-yGWW5Rr+sQOhK0Ot8hjDJuxU3XLRQGflvT4lhlSY0DFvdb3TwKaY26CJzHtYllU0vT9j58hc37ndFPsqT1SrzA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-private-methods": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-methods/-/plugin-transform-private-methods-7.24.7.tgz", + "integrity": "sha512-COTCOkG2hn4JKGEKBADkA8WNb35TGkkRbI5iT845dB+NyqgO8Hn+ajPbSnIQznneJTa3d30scb6iz/DhH8GsJQ==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-private-property-in-object": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.24.7.tgz", + "integrity": "sha512-9z76mxwnwFxMyxZWEgdgECQglF2Q7cFLm0kMf8pGwt+GSJsY0cONKj/UuO4bOH0w/uAel3ekS4ra5CEAyJRmDA==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-property-literals": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.24.7.tgz", + "integrity": "sha512-EMi4MLQSHfd2nrCqQEWxFdha2gBCqU4ZcCng4WBGZ5CJL4bBRW0ptdqqDdeirGZcpALazVVNJqRmsO8/+oNCBA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-regenerator": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.24.7.tgz", + "integrity": "sha512-lq3fvXPdimDrlg6LWBoqj+r/DEWgONuwjuOuQCSYgRroXDH/IdM1C0IZf59fL5cHLpjEH/O6opIRBbqv7ELnuA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "regenerator-transform": "^0.15.2" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-reserved-words": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.24.7.tgz", + "integrity": "sha512-0DUq0pHcPKbjFZCfTss/pGkYMfy3vFWydkUBd9r0GHpIyfs2eCDENvqadMycRS9wZCXR41wucAfJHJmwA0UmoQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-runtime": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.24.7.tgz", + "integrity": "sha512-YqXjrk4C+a1kZjewqt+Mmu2UuV1s07y8kqcUf4qYLnoqemhR4gRQikhdAhSVJioMjVTu6Mo6pAbaypEA3jY6fw==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "babel-plugin-polyfill-corejs2": "^0.4.10", + "babel-plugin-polyfill-corejs3": "^0.10.1", + "babel-plugin-polyfill-regenerator": "^0.6.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-runtime/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/plugin-transform-shorthand-properties": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.24.7.tgz", + "integrity": "sha512-KsDsevZMDsigzbA09+vacnLpmPH4aWjcZjXdyFKGzpplxhbeB4wYtury3vglQkg6KM/xEPKt73eCjPPf1PgXBA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-spread": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.24.7.tgz", + "integrity": "sha512-x96oO0I09dgMDxJaANcRyD4ellXFLLiWhuwDxKZX5g2rWP1bTPkBSwCYv96VDXVT1bD9aPj8tppr5ITIh8hBng==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-sticky-regex": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.24.7.tgz", + "integrity": "sha512-kHPSIJc9v24zEml5geKg9Mjx5ULpfncj0wRpYtxbvKyTtHCYDkVE3aHQ03FrpEo4gEe2vrJJS1Y9CJTaThA52g==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-template-literals": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.24.7.tgz", + "integrity": "sha512-AfDTQmClklHCOLxtGoP7HkeMw56k1/bTQjwsfhL6pppo/M4TOBSq+jjBUBLmV/4oeFg4GWMavIl44ZeCtmmZTw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-typeof-symbol": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.24.8.tgz", + "integrity": "sha512-adNTUpDCVnmAE58VEqKlAA6ZBlNkMnWD0ZcW76lyNFN3MJniyGFZfNwERVk8Ap56MCnXztmDr19T4mPTztcuaw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.8" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-escapes": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.24.7.tgz", + "integrity": "sha512-U3ap1gm5+4edc2Q/P+9VrBNhGkfnf+8ZqppY71Bo/pzZmXhhLdqgaUl6cuB07O1+AQJtCLfaOmswiNbSQ9ivhw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-property-regex": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-property-regex/-/plugin-transform-unicode-property-regex-7.24.7.tgz", + "integrity": "sha512-uH2O4OV5M9FZYQrwc7NdVmMxQJOCCzFeYudlZSzUAHRFeOujQefa92E74TQDVskNHCzOXoigEuoyzHDhaEaK5w==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-regex": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.24.7.tgz", + "integrity": "sha512-hlQ96MBZSAXUq7ltkjtu3FJCCSMx/j629ns3hA3pXnBXjanNP0LHi+JpPeA81zaWgVK1VGH95Xuy7u0RyQ8kMg==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-sets-regex": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-sets-regex/-/plugin-transform-unicode-sets-regex-7.24.7.tgz", + "integrity": "sha512-2G8aAvF4wy1w/AGZkemprdGMRg5o6zPNhbHVImRz3lss55TYCBd6xStN19rt8XJHq20sqV0JbyWjOWwQRwV/wg==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/preset-env": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.24.7.tgz", + "integrity": "sha512-1YZNsc+y6cTvWlDHidMBsQZrZfEFjRIo/BZCT906PMdzOyXtSLTgqGdrpcuTDCXyd11Am5uQULtDIcCfnTc8fQ==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.24.7", + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-validator-option": "^7.24.7", + "@babel/plugin-bugfix-firefox-class-in-computed-class-key": "^7.24.7", + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.24.7", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.24.7", + "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": "^7.24.7", + "@babel/plugin-proposal-private-property-in-object": "7.21.0-placeholder-for-preset-env.2", + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3", + "@babel/plugin-syntax-import-assertions": "^7.24.7", + "@babel/plugin-syntax-import-attributes": "^7.24.7", + "@babel/plugin-syntax-import-meta": "^7.10.4", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5", + "@babel/plugin-syntax-unicode-sets-regex": "^7.18.6", + "@babel/plugin-transform-arrow-functions": "^7.24.7", + "@babel/plugin-transform-async-generator-functions": "^7.24.7", + "@babel/plugin-transform-async-to-generator": "^7.24.7", + "@babel/plugin-transform-block-scoped-functions": "^7.24.7", + "@babel/plugin-transform-block-scoping": "^7.24.7", + "@babel/plugin-transform-class-properties": "^7.24.7", + "@babel/plugin-transform-class-static-block": "^7.24.7", + "@babel/plugin-transform-classes": "^7.24.7", + "@babel/plugin-transform-computed-properties": "^7.24.7", + "@babel/plugin-transform-destructuring": "^7.24.7", + "@babel/plugin-transform-dotall-regex": "^7.24.7", + "@babel/plugin-transform-duplicate-keys": "^7.24.7", + "@babel/plugin-transform-dynamic-import": "^7.24.7", + "@babel/plugin-transform-exponentiation-operator": "^7.24.7", + "@babel/plugin-transform-export-namespace-from": "^7.24.7", + "@babel/plugin-transform-for-of": "^7.24.7", + "@babel/plugin-transform-function-name": "^7.24.7", + "@babel/plugin-transform-json-strings": "^7.24.7", + "@babel/plugin-transform-literals": "^7.24.7", + "@babel/plugin-transform-logical-assignment-operators": "^7.24.7", + "@babel/plugin-transform-member-expression-literals": "^7.24.7", + "@babel/plugin-transform-modules-amd": "^7.24.7", + "@babel/plugin-transform-modules-commonjs": "^7.24.7", + "@babel/plugin-transform-modules-systemjs": "^7.24.7", + "@babel/plugin-transform-modules-umd": "^7.24.7", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.24.7", + "@babel/plugin-transform-new-target": "^7.24.7", + "@babel/plugin-transform-nullish-coalescing-operator": "^7.24.7", + "@babel/plugin-transform-numeric-separator": "^7.24.7", + "@babel/plugin-transform-object-rest-spread": "^7.24.7", + "@babel/plugin-transform-object-super": "^7.24.7", + "@babel/plugin-transform-optional-catch-binding": "^7.24.7", + "@babel/plugin-transform-optional-chaining": "^7.24.7", + "@babel/plugin-transform-parameters": "^7.24.7", + "@babel/plugin-transform-private-methods": "^7.24.7", + "@babel/plugin-transform-private-property-in-object": "^7.24.7", + "@babel/plugin-transform-property-literals": "^7.24.7", + "@babel/plugin-transform-regenerator": "^7.24.7", + "@babel/plugin-transform-reserved-words": "^7.24.7", + "@babel/plugin-transform-shorthand-properties": "^7.24.7", + "@babel/plugin-transform-spread": "^7.24.7", + "@babel/plugin-transform-sticky-regex": "^7.24.7", + "@babel/plugin-transform-template-literals": "^7.24.7", + "@babel/plugin-transform-typeof-symbol": "^7.24.7", + "@babel/plugin-transform-unicode-escapes": "^7.24.7", + "@babel/plugin-transform-unicode-property-regex": "^7.24.7", + "@babel/plugin-transform-unicode-regex": "^7.24.7", + "@babel/plugin-transform-unicode-sets-regex": "^7.24.7", + "@babel/preset-modules": "0.1.6-no-external-plugins", + "babel-plugin-polyfill-corejs2": "^0.4.10", + "babel-plugin-polyfill-corejs3": "^0.10.4", + "babel-plugin-polyfill-regenerator": "^0.6.1", + "core-js-compat": "^3.31.0", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/preset-env/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/preset-modules": { + "version": "0.1.6-no-external-plugins", + "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.6-no-external-plugins.tgz", + "integrity": "sha512-HrcgcIESLm9aIR842yhJ5RWan/gebQUJ6E/E5+rf0y9o6oj7w0Br+sWuL6kEQ/o/AdfvR1Je9jG18/gnpwjEyA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/types": "^7.4.4", + "esutils": "^2.0.2" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/@babel/regjsgen": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/@babel/regjsgen/-/regjsgen-0.8.0.tgz", + "integrity": "sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==", + "dev": true + }, + "node_modules/@babel/runtime": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.7.tgz", + "integrity": "sha512-UwgBRMjJP+xv857DCngvqXI3Iq6J4v0wXmwc6sapg+zyhbwmQX67LUEFrkK5tbyJ30jGuG3ZvWpBiB9LCy1kWw==", + "dev": true, + "dependencies": { + "regenerator-runtime": "^0.14.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/template": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.24.7.tgz", + "integrity": "sha512-jYqfPrU9JTF0PmPy1tLYHW4Mp4KlgxJD9l2nP9fD6yT/ICi554DmrWBAEYpIelzjHf1msDP3PxJIRt/nFNfBig==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.24.7", + "@babel/parser": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.24.8.tgz", + "integrity": "sha512-t0P1xxAPzEDcEPmjprAQq19NWum4K0EQPjMwZQZbHt+GiZqvjCHjj755Weq1YRPVzBI+3zSfvScfpnuIecVFJQ==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.24.8", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-hoist-variables": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", + "@babel/parser": "^7.24.8", + "@babel/types": "^7.24.8", + "debug": "^4.3.1", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse/node_modules/@babel/generator": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.24.8.tgz", + "integrity": "sha512-47DG+6F5SzOi0uEvK4wMShmn5yY0mVjVJoWTphdY2B4Rx9wHgjK7Yhtr0ru6nE+sn0v38mzrWOlah0p/YlHHOQ==", + "dev": true, + "dependencies": { + "@babel/types": "^7.24.8", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", + "jsesc": "^2.5.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/types": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.24.8.tgz", + "integrity": "sha512-SkSBEHwwJRU52QEVZBmMBnE5Ux2/6WU1grdYyOhpbCNxbmJrDuDCphBzKZSO3taf0zztp+qkWlymE5tVL5l0TA==", + "dev": true, + "dependencies": { + "@babel/helper-string-parser": "^7.24.8", + "@babel/helper-validator-identifier": "^7.24.7", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@colors/colors": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@colors/colors/-/colors-1.5.0.tgz", + "integrity": "sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==", + "dev": true, + "engines": { + "node": ">=0.1.90" + } + }, + "node_modules/@discoveryjs/json-ext": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz", + "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==", + "dev": true, + "engines": { + "node": ">=10.0.0" + } + }, + "node_modules/@esbuild/aix-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", + "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "aix" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", + "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", + "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", + "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", + "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", + "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", + "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", + "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", + "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", + "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", + "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-loong64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", + "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", + "cpu": [ + "loong64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-mips64el": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", + "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", + "cpu": [ + "mips64el" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", + "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-riscv64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", + "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-s390x": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", + "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", + "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/netbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", + "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/openbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", + "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/sunos-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", + "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", + "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", + "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", + "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@inquirer/checkbox": { + "version": "2.3.10", + "resolved": "https://registry.npmjs.org/@inquirer/checkbox/-/checkbox-2.3.10.tgz", + "integrity": "sha512-CTc864M2/523rKc9AglIzAcUCuPXDZENgc5S2KZFVRbnMzpXcYTsUWmbqSeL0XLvtlvEtNevkkVbfVhJpruOyQ==", + "dev": true, + "dependencies": { + "@inquirer/core": "^9.0.2", + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "ansi-escapes": "^4.3.2", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/checkbox/node_modules/@inquirer/core": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.0.2.tgz", + "integrity": "sha512-nguvH3TZar3ACwbytZrraRTzGqyxJfYJwv+ZwqZNatAosdWQMP1GV8zvmkNlBe2JeZSaw0WYBHZk52pDpWC9qA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/confirm": { + "version": "3.1.11", + "resolved": "https://registry.npmjs.org/@inquirer/confirm/-/confirm-3.1.11.tgz", + "integrity": "sha512-3wWw10VPxQP279FO4bzWsf8YjIAq7NdwATJ4xS2h1uwsXZu/RmtOVV95rZ7yllS1h/dzu+uLewjMAzNDEj8h2w==", + "dev": true, + "dependencies": { + "@inquirer/core": "^8.2.4", + "@inquirer/type": "^1.3.3" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/core": { + "version": "8.2.4", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-8.2.4.tgz", + "integrity": "sha512-7vsXSfxtrrbwMTirfaKwPcjqJy7pzeuF/bP62yo1NQrRJ5HjmMlrhZml/Ljm9ODc1RnbhJlTeSnCkjtFddKjwA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.3.3", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "picocolors": "^1.0.1", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/editor": { + "version": "2.1.14", + "resolved": "https://registry.npmjs.org/@inquirer/editor/-/editor-2.1.14.tgz", + "integrity": "sha512-6nWpoJyVAKwAcv67bkbBmmi3f32xua79fP7TRmNUoR4K+B1GiOBsHO1YdvET/jvC+nTlBZL7puKAKyM7G+Lkzw==", + "dev": true, + "dependencies": { + "@inquirer/core": "^9.0.2", + "@inquirer/type": "^1.4.0", + "external-editor": "^3.1.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/editor/node_modules/@inquirer/core": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.0.2.tgz", + "integrity": "sha512-nguvH3TZar3ACwbytZrraRTzGqyxJfYJwv+ZwqZNatAosdWQMP1GV8zvmkNlBe2JeZSaw0WYBHZk52pDpWC9qA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/expand": { + "version": "2.1.14", + "resolved": "https://registry.npmjs.org/@inquirer/expand/-/expand-2.1.14.tgz", + "integrity": "sha512-JcxsLajwPykF2kq6biIUdoOzTQ3LXqb8XMVrWkCprG/pFeU1SsxcSSFbF1T5jJGvvlTVcsE+JdGjbQ8ZRZ82RA==", + "dev": true, + "dependencies": { + "@inquirer/core": "^9.0.2", + "@inquirer/type": "^1.4.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/expand/node_modules/@inquirer/core": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.0.2.tgz", + "integrity": "sha512-nguvH3TZar3ACwbytZrraRTzGqyxJfYJwv+ZwqZNatAosdWQMP1GV8zvmkNlBe2JeZSaw0WYBHZk52pDpWC9qA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/figures": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/@inquirer/figures/-/figures-1.0.3.tgz", + "integrity": "sha512-ErXXzENMH5pJt5/ssXV0DfWUZqly8nGzf0UcBV9xTnP+KyffE2mqyxIMBrZ8ijQck2nU0TQm40EQB53YreyWHw==", + "dev": true, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/input": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@inquirer/input/-/input-2.2.1.tgz", + "integrity": "sha512-Yl1G6h7qWydzrJwqN777geeJVaAFL5Ly83aZlw4xHf8Z/BoTMfKRheyuMaQwOG7LQ4e5nQP7PxXdEg4SzQ+OKw==", + "dev": true, + "dependencies": { + "@inquirer/core": "^9.0.2", + "@inquirer/type": "^1.4.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/input/node_modules/@inquirer/core": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.0.2.tgz", + "integrity": "sha512-nguvH3TZar3ACwbytZrraRTzGqyxJfYJwv+ZwqZNatAosdWQMP1GV8zvmkNlBe2JeZSaw0WYBHZk52pDpWC9qA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/password": { + "version": "2.1.14", + "resolved": "https://registry.npmjs.org/@inquirer/password/-/password-2.1.14.tgz", + "integrity": "sha512-sPzOkXLhWJQ96K6nPZFnF8XB8tsDrcCRobd1d3EDz81F+4hp8BbdmsnsQcqZ7oYDIOVM/mWJyIUtJ35TrssJxQ==", + "dev": true, + "dependencies": { + "@inquirer/core": "^9.0.2", + "@inquirer/type": "^1.4.0", + "ansi-escapes": "^4.3.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/password/node_modules/@inquirer/core": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.0.2.tgz", + "integrity": "sha512-nguvH3TZar3ACwbytZrraRTzGqyxJfYJwv+ZwqZNatAosdWQMP1GV8zvmkNlBe2JeZSaw0WYBHZk52pDpWC9qA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/prompts": { + "version": "5.0.7", + "resolved": "https://registry.npmjs.org/@inquirer/prompts/-/prompts-5.0.7.tgz", + "integrity": "sha512-GFcigCxJTKCH3aECzMIu4FhgLJWnFvMXzpI4CCSoELWFtkOOU2P+goYA61+OKpGrB8fPE7q6n8zAXBSlZRrHjQ==", + "dev": true, + "dependencies": { + "@inquirer/checkbox": "^2.3.7", + "@inquirer/confirm": "^3.1.11", + "@inquirer/editor": "^2.1.11", + "@inquirer/expand": "^2.1.11", + "@inquirer/input": "^2.1.11", + "@inquirer/password": "^2.1.11", + "@inquirer/rawlist": "^2.1.11", + "@inquirer/select": "^2.3.7" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/rawlist": { + "version": "2.1.14", + "resolved": "https://registry.npmjs.org/@inquirer/rawlist/-/rawlist-2.1.14.tgz", + "integrity": "sha512-pLpEzhKNQ/ugFAFfgCNaXljB+dcCwmXwR1jOxAbVeFIdB3l02E5gjI+h1rb136tq0T8JO6P5KFR1oTeld/wdrA==", + "dev": true, + "dependencies": { + "@inquirer/core": "^9.0.2", + "@inquirer/type": "^1.4.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/rawlist/node_modules/@inquirer/core": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.0.2.tgz", + "integrity": "sha512-nguvH3TZar3ACwbytZrraRTzGqyxJfYJwv+ZwqZNatAosdWQMP1GV8zvmkNlBe2JeZSaw0WYBHZk52pDpWC9qA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/select": { + "version": "2.3.10", + "resolved": "https://registry.npmjs.org/@inquirer/select/-/select-2.3.10.tgz", + "integrity": "sha512-rr7iR0Zj1YFfgM8IUGimPD9Yukd+n/U63CnYT9kdum6DbRXtMxR45rrreP+EA9ixCnShr+W4xj7suRxC1+8t9g==", + "dev": true, + "dependencies": { + "@inquirer/core": "^9.0.2", + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "ansi-escapes": "^4.3.2", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/select/node_modules/@inquirer/core": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.0.2.tgz", + "integrity": "sha512-nguvH3TZar3ACwbytZrraRTzGqyxJfYJwv+ZwqZNatAosdWQMP1GV8zvmkNlBe2JeZSaw0WYBHZk52pDpWC9qA==", + "dev": true, + "dependencies": { + "@inquirer/figures": "^1.0.3", + "@inquirer/type": "^1.4.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^20.14.9", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-spinners": "^2.9.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/type": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@inquirer/type/-/type-1.4.0.tgz", + "integrity": "sha512-AjOqykVyjdJQvtfkNDGUyMYGF8xN50VUxftCQWsOyIo4DFRLr6VQhW0VItGI1JIyQGCGgIpKa7hMMwNhZb4OIw==", + "dev": true, + "dependencies": { + "mute-stream": "^1.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@isaacs/cliui": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", + "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", + "dev": true, + "dependencies": { + "string-width": "^5.1.2", + "string-width-cjs": "npm:string-width@^4.2.0", + "strip-ansi": "^7.0.1", + "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", + "wrap-ansi": "^8.1.0", + "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/@isaacs/cliui/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/@isaacs/cliui/node_modules/ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/@isaacs/cliui/node_modules/emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", + "dev": true + }, + "node_modules/@isaacs/cliui/node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "dev": true, + "dependencies": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@isaacs/cliui/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "dev": true, + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/@isaacs/cliui/node_modules/wrap-ansi": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", + "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^6.1.0", + "string-width": "^5.0.1", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/@istanbuljs/schema": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", + "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", + "dev": true, + "dependencies": { + "@jridgewell/set-array": "^1.2.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/source-map": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.6.tgz", + "integrity": "sha512-1ZJTZebgqllO79ue2bm3rIGud/bOe0pP5BjSRCRxxYkEZS8STV7zN84UBbiYu7jy+eCKSnVIUgoWWE/tt+shMQ==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", + "dev": true + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", + "dev": true, + "dependencies": { + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "node_modules/@jsonjoy.com/base64": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jsonjoy.com/base64/-/base64-1.1.2.tgz", + "integrity": "sha512-q6XAnWQDIMA3+FTiOYajoYqySkO+JSat0ytXGSuRdq9uXE7o92gzuQwQM14xaCRlBLGq3v5miDGC4vkVTn54xA==", + "dev": true, + "engines": { + "node": ">=10.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/streamich" + }, + "peerDependencies": { + "tslib": "2" + } + }, + "node_modules/@jsonjoy.com/json-pack": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/@jsonjoy.com/json-pack/-/json-pack-1.0.4.tgz", + "integrity": "sha512-aOcSN4MeAtFROysrbqG137b7gaDDSmVrl5mpo6sT/w+kcXpWnzhMjmY/Fh/sDx26NBxyIE7MB1seqLeCAzy9Sg==", + "dev": true, + "dependencies": { + "@jsonjoy.com/base64": "^1.1.1", + "@jsonjoy.com/util": "^1.1.2", + "hyperdyperid": "^1.2.0", + "thingies": "^1.20.0" + }, + "engines": { + "node": ">=10.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/streamich" + }, + "peerDependencies": { + "tslib": "2" + } + }, + "node_modules/@jsonjoy.com/util": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@jsonjoy.com/util/-/util-1.2.0.tgz", + "integrity": "sha512-4B8B+3vFsY4eo33DMKyJPlQ3sBMpPFUZK2dr3O3rXrOGKKbYG44J0XSFkDo1VOQiri5HFEhIeVvItjR2xcazmg==", + "dev": true, + "engines": { + "node": ">=10.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/streamich" + }, + "peerDependencies": { + "tslib": "2" + } + }, + "node_modules/@leichtgewicht/ip-codec": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@leichtgewicht/ip-codec/-/ip-codec-2.0.5.tgz", + "integrity": "sha512-Vo+PSpZG2/fmgmiNzYK9qWRh8h/CHrwD0mo1h1DzL4yzHNSfWYujGTYsWGreD000gcgmZ7K4Ys6Tx9TxtsKdDw==", + "dev": true + }, + "node_modules/@listr2/prompt-adapter-inquirer": { + "version": "2.0.13", + "resolved": "https://registry.npmjs.org/@listr2/prompt-adapter-inquirer/-/prompt-adapter-inquirer-2.0.13.tgz", + "integrity": "sha512-nAl6teTt7EWSjttNavAnv3uFR3w3vPP3OTYmHyPNHzKhAj2NoBDHmbS3MGpvvO8KXXPASnHjEGrrKrdKTMKPnQ==", + "dev": true, + "dependencies": { + "@inquirer/type": "^1.3.3" + }, + "engines": { + "node": ">=18.0.0" + }, + "peerDependencies": { + "@inquirer/prompts": ">= 3 < 6" + } + }, + "node_modules/@lmdb/lmdb-darwin-arm64": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/@lmdb/lmdb-darwin-arm64/-/lmdb-darwin-arm64-3.0.12.tgz", + "integrity": "sha512-vgTwzNUD3Hy4aqtGhX2+nV/usI0mwy3hDRuTjs8VcK0BLiMVEpNQXgzwlWEgPmA8AAPloUgyOs2nK5clJF5oIg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@lmdb/lmdb-darwin-x64": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/@lmdb/lmdb-darwin-x64/-/lmdb-darwin-x64-3.0.12.tgz", + "integrity": "sha512-qOt0hAhj2ZLY6aEWu85rzt5zcyCAQITMhCMEPNlo1tuYekpVAdkQNiwXxEkCjBYvwTskvXuwXOOUpjuSc+aJnA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@lmdb/lmdb-linux-arm": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/@lmdb/lmdb-linux-arm/-/lmdb-linux-arm-3.0.12.tgz", + "integrity": "sha512-Ggd/UXpE+alMncbELCXA3OKpDj9bDBR3qVO7WRTxstloDglRAHfZmUJgTkeaNKjFO1JHqS7AKy0jba9XebZB1w==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@lmdb/lmdb-linux-arm64": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/@lmdb/lmdb-linux-arm64/-/lmdb-linux-arm64-3.0.12.tgz", + "integrity": "sha512-Qy4cFXFe9h1wAWMsojex8x1ifvw2kqiZv686YiRTdQEzAfc3vJASHFcD/QejHUCx7YHMYdnUoCS45rG2AiGDTQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@lmdb/lmdb-linux-x64": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/@lmdb/lmdb-linux-x64/-/lmdb-linux-x64-3.0.12.tgz", + "integrity": "sha512-c+noT9IofktxktFllKHFmci8ka2SYGSLN17pj/KSl1hg7mmfAiGp4xxFxEwMLTb+SX95vP1DFiR++1I3WLVxvA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@lmdb/lmdb-win32-x64": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/@lmdb/lmdb-win32-x64/-/lmdb-win32-x64-3.0.12.tgz", + "integrity": "sha512-CO3MFV8gUx16NU/CyyuumAKblESwvoGVA2XhQKZ976OTOxaTbb8F8D3f0iiZ4MYqsN74jIrFuCmXpPnpjbhfOQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@msgpackr-extract/msgpackr-extract-darwin-arm64": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-darwin-arm64/-/msgpackr-extract-darwin-arm64-3.0.3.tgz", + "integrity": "sha512-QZHtlVgbAdy2zAqNA9Gu1UpIuI8Xvsd1v8ic6B2pZmeFnFcMWiPLfWXh7TVw4eGEZ/C9TH281KwhVoeQUKbyjw==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@msgpackr-extract/msgpackr-extract-darwin-x64": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-darwin-x64/-/msgpackr-extract-darwin-x64-3.0.3.tgz", + "integrity": "sha512-mdzd3AVzYKuUmiWOQ8GNhl64/IoFGol569zNRdkLReh6LRLHOXxU4U8eq0JwaD8iFHdVGqSy4IjFL4reoWCDFw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@msgpackr-extract/msgpackr-extract-linux-arm": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-arm/-/msgpackr-extract-linux-arm-3.0.3.tgz", + "integrity": "sha512-fg0uy/dG/nZEXfYilKoRe7yALaNmHoYeIoJuJ7KJ+YyU2bvY8vPv27f7UKhGRpY6euFYqEVhxCFZgAUNQBM3nw==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@msgpackr-extract/msgpackr-extract-linux-arm64": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-arm64/-/msgpackr-extract-linux-arm64-3.0.3.tgz", + "integrity": "sha512-YxQL+ax0XqBJDZiKimS2XQaf+2wDGVa1enVRGzEvLLVFeqa5kx2bWbtcSXgsxjQB7nRqqIGFIcLteF/sHeVtQg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@msgpackr-extract/msgpackr-extract-linux-x64": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-x64/-/msgpackr-extract-linux-x64-3.0.3.tgz", + "integrity": "sha512-cvwNfbP07pKUfq1uH+S6KJ7dT9K8WOE4ZiAcsrSes+UY55E/0jLYc+vq+DO7jlmqRb5zAggExKm0H7O/CBaesg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@msgpackr-extract/msgpackr-extract-win32-x64": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-win32-x64/-/msgpackr-extract-win32-x64-3.0.3.tgz", + "integrity": "sha512-x0fWaQtYp4E6sktbsdAqnehxDgEc/VwM7uLsRCYWaiGu0ykYdZPiS8zCWdnjHwyiumousxfBm4SO31eXqwEZhQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@ngtools/webpack": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-18.1.0.tgz", + "integrity": "sha512-J4ATDGq0AubLbP3DOFRjp0pDBvSgzjtiu5l1hGq3xf6AzVAEmZFlp2Ac2EykuK2r8XDnCVoLrxICJOXZWWzP2g==", + "dev": true, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + }, + "peerDependencies": { + "@angular/compiler-cli": "^18.0.0", + "typescript": ">=5.4 <5.6", + "webpack": "^5.54.0" + } + }, + "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/@npmcli/agent": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/@npmcli/agent/-/agent-2.2.2.tgz", + "integrity": "sha512-OrcNPXdpSl9UX7qPVRWbmWMCSXrcDa2M9DvrbOTj7ao1S4PlqVFYv9/yLKMkrJKZ/V5A/kDBC690or307i26Og==", + "dev": true, + "dependencies": { + "agent-base": "^7.1.0", + "http-proxy-agent": "^7.0.0", + "https-proxy-agent": "^7.0.1", + "lru-cache": "^10.0.1", + "socks-proxy-agent": "^8.0.3" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/agent/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", + "dev": true + }, + "node_modules/@npmcli/fs": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/@npmcli/fs/-/fs-3.1.1.tgz", + "integrity": "sha512-q9CRWjpHCMIh5sVyefoD1cA7PkvILqCZsnSOEUUivORLjxCO/Irmue2DprETiNgEqktDBZaM1Bi+jrarx1XdCg==", + "dev": true, + "dependencies": { + "semver": "^7.3.5" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/git": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/@npmcli/git/-/git-5.0.8.tgz", + "integrity": "sha512-liASfw5cqhjNW9UFd+ruwwdEf/lbOAQjLL2XY2dFW/bkJheXDYZgOyul/4gVvEV4BWkTXjYGmDqMw9uegdbJNQ==", + "dev": true, + "dependencies": { + "@npmcli/promise-spawn": "^7.0.0", + "ini": "^4.1.3", + "lru-cache": "^10.0.1", + "npm-pick-manifest": "^9.0.0", + "proc-log": "^4.0.0", + "promise-inflight": "^1.0.1", + "promise-retry": "^2.0.1", + "semver": "^7.3.5", + "which": "^4.0.0" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/git/node_modules/isexe": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-3.1.1.tgz", + "integrity": "sha512-LpB/54B+/2J5hqQ7imZHfdU31OlgQqx7ZicVlkm9kzg9/w8GKLEcFfJl/t7DCEDueOyBAD6zCCwTO6Fzs0NoEQ==", + "dev": true, + "engines": { + "node": ">=16" + } + }, + "node_modules/@npmcli/git/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", + "dev": true + }, + "node_modules/@npmcli/git/node_modules/which": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/which/-/which-4.0.0.tgz", + "integrity": "sha512-GlaYyEb07DPxYCKhKzplCWBJtvxZcZMrL+4UkrTSJHHPyZU4mYYTv3qaOe77H7EODLSSopAUFAc6W8U4yqvscg==", + "dev": true, + "dependencies": { + "isexe": "^3.1.1" + }, + "bin": { + "node-which": "bin/which.js" + }, + "engines": { + "node": "^16.13.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/installed-package-contents": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@npmcli/installed-package-contents/-/installed-package-contents-2.1.0.tgz", + "integrity": "sha512-c8UuGLeZpm69BryRykLuKRyKFZYJsZSCT4aVY5ds4omyZqJ172ApzgfKJ5eV/r3HgLdUYgFVe54KSFVjKoe27w==", + "dev": true, + "dependencies": { + "npm-bundled": "^3.0.0", + "npm-normalize-package-bin": "^3.0.0" + }, + "bin": { + "installed-package-contents": "bin/index.js" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/node-gyp": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@npmcli/node-gyp/-/node-gyp-3.0.0.tgz", + "integrity": "sha512-gp8pRXC2oOxu0DUE1/M3bYtb1b3/DbJ5aM113+XJBgfXdussRAsX0YOrOhdd8WvnAR6auDBvJomGAkLKA5ydxA==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/package-json": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@npmcli/package-json/-/package-json-5.2.0.tgz", + "integrity": "sha512-qe/kiqqkW0AGtvBjL8TJKZk/eBBSpnJkUWvHdQ9jM2lKHXRYYJuyNpJPlJw3c8QjC2ow6NZYiLExhUaeJelbxQ==", + "dev": true, + "dependencies": { + "@npmcli/git": "^5.0.0", + "glob": "^10.2.2", + "hosted-git-info": "^7.0.0", + "json-parse-even-better-errors": "^3.0.0", + "normalize-package-data": "^6.0.0", + "proc-log": "^4.0.0", + "semver": "^7.5.3" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/package-json/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/@npmcli/package-json/node_modules/glob": { + "version": "10.4.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", + "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", + "dev": true, + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^3.1.2", + "minimatch": "^9.0.4", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^1.11.1" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@npmcli/package-json/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@npmcli/promise-spawn": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@npmcli/promise-spawn/-/promise-spawn-7.0.2.tgz", + "integrity": "sha512-xhfYPXoV5Dy4UkY0D+v2KkwvnDfiA/8Mt3sWCGI/hM03NsYIH8ZaG6QzS9x7pje5vHZBZJ2v6VRFVTWACnqcmQ==", + "dev": true, + "dependencies": { + "which": "^4.0.0" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/promise-spawn/node_modules/isexe": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-3.1.1.tgz", + "integrity": "sha512-LpB/54B+/2J5hqQ7imZHfdU31OlgQqx7ZicVlkm9kzg9/w8GKLEcFfJl/t7DCEDueOyBAD6zCCwTO6Fzs0NoEQ==", + "dev": true, + "engines": { + "node": ">=16" + } + }, + "node_modules/@npmcli/promise-spawn/node_modules/which": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/which/-/which-4.0.0.tgz", + "integrity": "sha512-GlaYyEb07DPxYCKhKzplCWBJtvxZcZMrL+4UkrTSJHHPyZU4mYYTv3qaOe77H7EODLSSopAUFAc6W8U4yqvscg==", + "dev": true, + "dependencies": { + "isexe": "^3.1.1" + }, + "bin": { + "node-which": "bin/which.js" + }, + "engines": { + "node": "^16.13.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/redact": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@npmcli/redact/-/redact-2.0.1.tgz", + "integrity": "sha512-YgsR5jCQZhVmTJvjduTOIHph0L73pK8xwMVaDY0PatySqVM9AZj93jpoXYSJqfHFxFkN9dmqTw6OiqExsS3LPw==", + "dev": true, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/run-script": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/@npmcli/run-script/-/run-script-8.1.0.tgz", + "integrity": "sha512-y7efHHwghQfk28G2z3tlZ67pLG0XdfYbcVG26r7YIXALRsrVQcTq4/tdenSmdOrEsNahIYA/eh8aEVROWGFUDg==", + "dev": true, + "dependencies": { + "@npmcli/node-gyp": "^3.0.0", + "@npmcli/package-json": "^5.0.0", + "@npmcli/promise-spawn": "^7.0.0", + "node-gyp": "^10.0.0", + "proc-log": "^4.0.0", + "which": "^4.0.0" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@npmcli/run-script/node_modules/isexe": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-3.1.1.tgz", + "integrity": "sha512-LpB/54B+/2J5hqQ7imZHfdU31OlgQqx7ZicVlkm9kzg9/w8GKLEcFfJl/t7DCEDueOyBAD6zCCwTO6Fzs0NoEQ==", + "dev": true, + "engines": { + "node": ">=16" + } + }, + "node_modules/@npmcli/run-script/node_modules/which": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/which/-/which-4.0.0.tgz", + "integrity": "sha512-GlaYyEb07DPxYCKhKzplCWBJtvxZcZMrL+4UkrTSJHHPyZU4mYYTv3qaOe77H7EODLSSopAUFAc6W8U4yqvscg==", + "dev": true, + "dependencies": { + "isexe": "^3.1.1" + }, + "bin": { + "node-which": "bin/which.js" + }, + "engines": { + "node": "^16.13.0 || >=18.0.0" + } + }, + "node_modules/@pkgjs/parseargs": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", + "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", + "dev": true, + "optional": true, + "engines": { + "node": ">=14" + } + }, + "node_modules/@rollup/rollup-android-arm-eabi": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.18.0.tgz", + "integrity": "sha512-Tya6xypR10giZV1XzxmH5wr25VcZSncG0pZIjfePT0OVBvqNEurzValetGNarVrGiq66EBVAFn15iYX4w6FKgQ==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-android-arm64": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.18.0.tgz", + "integrity": "sha512-avCea0RAP03lTsDhEyfy+hpfr85KfyTctMADqHVhLAF3MlIkq83CP8UfAHUssgXTYd+6er6PaAhx/QGv4L1EiA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-darwin-arm64": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.18.0.tgz", + "integrity": "sha512-IWfdwU7KDSm07Ty0PuA/W2JYoZ4iTj3TUQjkVsO/6U+4I1jN5lcR71ZEvRh52sDOERdnNhhHU57UITXz5jC1/w==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-darwin-x64": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.18.0.tgz", + "integrity": "sha512-n2LMsUz7Ynu7DoQrSQkBf8iNrjOGyPLrdSg802vk6XT3FtsgX6JbE8IHRvposskFm9SNxzkLYGSq9QdpLYpRNA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.18.0.tgz", + "integrity": "sha512-C/zbRYRXFjWvz9Z4haRxcTdnkPt1BtCkz+7RtBSuNmKzMzp3ZxdM28Mpccn6pt28/UWUCTXa+b0Mx1k3g6NOMA==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm-musleabihf": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.18.0.tgz", + "integrity": "sha512-l3m9ewPgjQSXrUMHg93vt0hYCGnrMOcUpTz6FLtbwljo2HluS4zTXFy2571YQbisTnfTKPZ01u/ukJdQTLGh9A==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-gnu": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.18.0.tgz", + "integrity": "sha512-rJ5D47d8WD7J+7STKdCUAgmQk49xuFrRi9pZkWoRD1UeSMakbcepWXPF8ycChBoAqs1pb2wzvbY6Q33WmN2ftw==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-musl": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.18.0.tgz", + "integrity": "sha512-be6Yx37b24ZwxQ+wOQXXLZqpq4jTckJhtGlWGZs68TgdKXJgw54lUUoFYrg6Zs/kjzAQwEwYbp8JxZVzZLRepQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.18.0.tgz", + "integrity": "sha512-hNVMQK+qrA9Todu9+wqrXOHxFiD5YmdEi3paj6vP02Kx1hjd2LLYR2eaN7DsEshg09+9uzWi2W18MJDlG0cxJA==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-riscv64-gnu": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.18.0.tgz", + "integrity": "sha512-ROCM7i+m1NfdrsmvwSzoxp9HFtmKGHEqu5NNDiZWQtXLA8S5HBCkVvKAxJ8U+CVctHwV2Gb5VUaK7UAkzhDjlg==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-s390x-gnu": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.18.0.tgz", + "integrity": "sha512-0UyyRHyDN42QL+NbqevXIIUnKA47A+45WyasO+y2bGJ1mhQrfrtXUpTxCOrfxCR4esV3/RLYyucGVPiUsO8xjg==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-gnu": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.18.0.tgz", + "integrity": "sha512-xuglR2rBVHA5UsI8h8UbX4VJ470PtGCf5Vpswh7p2ukaqBGFTnsfzxUBetoWBWymHMxbIG0Cmx7Y9qDZzr648w==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-musl": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.18.0.tgz", + "integrity": "sha512-LKaqQL9osY/ir2geuLVvRRs+utWUNilzdE90TpyoX0eNqPzWjRm14oMEE+YLve4k/NAqCdPkGYDaDF5Sw+xBfg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-win32-arm64-msvc": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.18.0.tgz", + "integrity": "sha512-7J6TkZQFGo9qBKH0pk2cEVSRhJbL6MtfWxth7Y5YmZs57Pi+4x6c2dStAUvaQkHQLnEQv1jzBUW43GvZW8OFqA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-ia32-msvc": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.18.0.tgz", + "integrity": "sha512-Txjh+IxBPbkUB9+SXZMpv+b/vnTEtFyfWZgJ6iyCmt2tdx0OF5WhFowLmnh8ENGNpfUlUZkdI//4IEmhwPieNg==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.18.0.tgz", + "integrity": "sha512-UOo5FdvOL0+eIVTgS4tIdbW+TtnBLWg1YBCcU2KWM7nuNwRz9bksDX1bekJJCpu25N1DVWaCwnT39dVQxzqS8g==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@schematics/angular": { + "version": "18.1.0", + "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-18.1.0.tgz", + "integrity": "sha512-k9Dy6JD7hqvCzDqnMjDm7J8H/P6m5mLuX2yEgQWKRAJ/YMINtBQAaKA1T9qXk97kEX6RNLpHMuDIsrIfK/H31Q==", + "dev": true, + "dependencies": { + "@angular-devkit/core": "18.1.0", + "@angular-devkit/schematics": "18.1.0", + "jsonc-parser": "3.3.1" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0", + "npm": "^6.11.0 || ^7.5.6 || >=8.0.0", + "yarn": ">= 1.13.0" + } + }, + "node_modules/@sigstore/bundle": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/@sigstore/bundle/-/bundle-2.3.2.tgz", + "integrity": "sha512-wueKWDk70QixNLB363yHc2D2ItTgYiMTdPwK8D9dKQMR3ZQ0c35IxP5xnwQ8cNLoCgCRcHf14kE+CLIvNX1zmA==", + "dev": true, + "dependencies": { + "@sigstore/protobuf-specs": "^0.3.2" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@sigstore/core": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@sigstore/core/-/core-1.1.0.tgz", + "integrity": "sha512-JzBqdVIyqm2FRQCulY6nbQzMpJJpSiJ8XXWMhtOX9eKgaXXpfNOF53lzQEjIydlStnd/eFtuC1dW4VYdD93oRg==", + "dev": true, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@sigstore/protobuf-specs": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@sigstore/protobuf-specs/-/protobuf-specs-0.3.2.tgz", + "integrity": "sha512-c6B0ehIWxMI8wiS/bj6rHMPqeFvngFV7cDU/MY+B16P9Z3Mp9k8L93eYZ7BYzSickzuqAQqAq0V956b3Ju6mLw==", + "dev": true, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@sigstore/sign": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/@sigstore/sign/-/sign-2.3.2.tgz", + "integrity": "sha512-5Vz5dPVuunIIvC5vBb0APwo7qKA4G9yM48kPWJT+OEERs40md5GoUR1yedwpekWZ4m0Hhw44m6zU+ObsON+iDA==", + "dev": true, + "dependencies": { + "@sigstore/bundle": "^2.3.2", + "@sigstore/core": "^1.0.0", + "@sigstore/protobuf-specs": "^0.3.2", + "make-fetch-happen": "^13.0.1", + "proc-log": "^4.2.0", + "promise-retry": "^2.0.1" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@sigstore/tuf": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/@sigstore/tuf/-/tuf-2.3.4.tgz", + "integrity": "sha512-44vtsveTPUpqhm9NCrbU8CWLe3Vck2HO1PNLw7RIajbB7xhtn5RBPm1VNSCMwqGYHhDsBJG8gDF0q4lgydsJvw==", + "dev": true, + "dependencies": { + "@sigstore/protobuf-specs": "^0.3.2", + "tuf-js": "^2.2.1" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@sigstore/verify": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@sigstore/verify/-/verify-1.2.1.tgz", + "integrity": "sha512-8iKx79/F73DKbGfRf7+t4dqrc0bRr0thdPrxAtCKWRm/F0tG71i6O1rvlnScncJLLBZHn3h8M3c1BSUAb9yu8g==", + "dev": true, + "dependencies": { + "@sigstore/bundle": "^2.3.2", + "@sigstore/core": "^1.1.0", + "@sigstore/protobuf-specs": "^0.3.2" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@sindresorhus/merge-streams": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@sindresorhus/merge-streams/-/merge-streams-2.3.0.tgz", + "integrity": "sha512-LtoMMhxAlorcGhmFYI+LhPgbPZCkgP6ra1YL604EeF6U98pLlQ3iWIGMdWSC+vWmPBWBNgmDBAhnAobLROJmwg==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@socket.io/component-emitter": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.1.2.tgz", + "integrity": "sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==", + "dev": true + }, + "node_modules/@tufjs/canonical-json": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@tufjs/canonical-json/-/canonical-json-2.0.0.tgz", + "integrity": "sha512-yVtV8zsdo8qFHe+/3kw81dSLyF7D576A5cCFCi4X7B39tWT7SekaEFUnvnWJHz+9qO7qJTah1JbrDjWKqFtdWA==", + "dev": true, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@tufjs/models": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@tufjs/models/-/models-2.0.1.tgz", + "integrity": "sha512-92F7/SFyufn4DXsha9+QfKnN03JGqtMFMXgSHbZOo8JG59WkTni7UzAouNQDf7AuP9OAMxVOPQcqG3sB7w+kkg==", + "dev": true, + "dependencies": { + "@tufjs/canonical-json": "2.0.0", + "minimatch": "^9.0.4" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/@tufjs/models/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/@tufjs/models/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@types/body-parser": { + "version": "1.19.5", + "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.5.tgz", + "integrity": "sha512-fB3Zu92ucau0iQ0JMCFQE7b/dv8Ot07NI3KaZIkIUNXq82k4eBAqUaneXfleGY9JWskeS9y+u0nXMyspcuQrCg==", + "dev": true, + "dependencies": { + "@types/connect": "*", + "@types/node": "*" + } + }, + "node_modules/@types/bonjour": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@types/bonjour/-/bonjour-3.5.13.tgz", + "integrity": "sha512-z9fJ5Im06zvUL548KvYNecEVlA7cVDkGUi6kZusb04mpyEFKCIZJvloCcmpmLaIahDpOQGHaHmG6imtPMmPXGQ==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/connect": { + "version": "3.4.38", + "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.38.tgz", + "integrity": "sha512-K6uROf1LD88uDQqJCktA4yzL1YYAK6NgfsI0v/mTgyPKWsX1CnJ0XPSDhViejru1GcRkLWb8RlzFYJRqGUbaug==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/connect-history-api-fallback": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.5.4.tgz", + "integrity": "sha512-n6Cr2xS1h4uAulPRdlw6Jl6s1oG8KrVilPN2yUITEs+K48EzMJJ3W1xy8K5eWuFvjp3R74AOIGSmp2UfBJ8HFw==", + "dev": true, + "dependencies": { + "@types/express-serve-static-core": "*", + "@types/node": "*" + } + }, + "node_modules/@types/cookie": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.4.1.tgz", + "integrity": "sha512-XW/Aa8APYr6jSVVA1y/DEIZX0/GMKLEVekNG727R8cs56ahETkRAy/3DR7+fJyh7oUgGwNQaRfXCun0+KbWY7Q==", + "dev": true + }, + "node_modules/@types/cors": { + "version": "2.8.17", + "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.17.tgz", + "integrity": "sha512-8CGDvrBj1zgo2qE+oS3pOCyYNqCPryMWY2bGfwA0dcfopWGgxs+78df0Rs3rc9THP4JkOhLsAa+15VdpAqkcUA==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/eslint": { + "version": "8.56.10", + "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.10.tgz", + "integrity": "sha512-Shavhk87gCtY2fhXDctcfS3e6FdxWkCx1iUZ9eEUbh7rTqlZT0/IzOkCOVt0fCjcFuZ9FPYfuezTBImfHCDBGQ==", + "dev": true, + "dependencies": { + "@types/estree": "*", + "@types/json-schema": "*" + } + }, + "node_modules/@types/eslint-scope": { + "version": "3.7.7", + "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.7.tgz", + "integrity": "sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==", + "dev": true, + "dependencies": { + "@types/eslint": "*", + "@types/estree": "*" + } + }, + "node_modules/@types/estree": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", + "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", + "dev": true + }, + "node_modules/@types/express": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.21.tgz", + "integrity": "sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ==", + "dev": true, + "dependencies": { + "@types/body-parser": "*", + "@types/express-serve-static-core": "^4.17.33", + "@types/qs": "*", + "@types/serve-static": "*" + } + }, + "node_modules/@types/express-serve-static-core": { + "version": "4.19.5", + "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.19.5.tgz", + "integrity": "sha512-y6W03tvrACO72aijJ5uF02FRq5cgDR9lUxddQ8vyF+GvmjJQqbzDcJngEjURc+ZsG31VI3hODNZJ2URj86pzmg==", + "dev": true, + "dependencies": { + "@types/node": "*", + "@types/qs": "*", + "@types/range-parser": "*", + "@types/send": "*" + } + }, + "node_modules/@types/http-errors": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@types/http-errors/-/http-errors-2.0.4.tgz", + "integrity": "sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA==", + "dev": true + }, + "node_modules/@types/http-proxy": { + "version": "1.17.14", + "resolved": "https://registry.npmjs.org/@types/http-proxy/-/http-proxy-1.17.14.tgz", + "integrity": "sha512-SSrD0c1OQzlFX7pGu1eXxSEjemej64aaNPRhhVYUGqXh0BtldAAx37MG8btcumvpgKyZp1F5Gn3JkktdxiFv6w==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/jasmine": { + "version": "5.1.4", + "resolved": "https://registry.npmjs.org/@types/jasmine/-/jasmine-5.1.4.tgz", + "integrity": "sha512-px7OMFO/ncXxixDe1zR13V1iycqWae0MxTaw62RpFlksUi5QuNWgQJFkTQjIOvrmutJbI7Fp2Y2N1F6D2R4G6w==", + "dev": true + }, + "node_modules/@types/json-schema": { + "version": "7.0.15", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", + "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", + "dev": true + }, + "node_modules/@types/mime": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.5.tgz", + "integrity": "sha512-/pyBZWSLD2n0dcHE3hq8s8ZvcETHtEuF+3E7XVt0Ig2nvsVQXdghHVcEkIWjy9A0wKfTn97a/PSDYohKIlnP/w==", + "dev": true + }, + "node_modules/@types/mute-stream": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/@types/mute-stream/-/mute-stream-0.0.4.tgz", + "integrity": "sha512-CPM9nzrCPPJHQNA9keH9CVkVI+WR5kMa+7XEs5jcGQ0VoAGnLv242w8lIVgwAEfmE4oufJRaTc9PNLQl0ioAow==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/node": { + "version": "20.14.10", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.10.tgz", + "integrity": "sha512-MdiXf+nDuMvY0gJKxyfZ7/6UFsETO7mGKF54MVD/ekJS6HdFtpZFBgrh6Pseu64XTb2MLyFPlbW6hj8HYRQNOQ==", + "dev": true, + "dependencies": { + "undici-types": "~5.26.4" + } + }, + "node_modules/@types/node-forge": { + "version": "1.3.11", + "resolved": "https://registry.npmjs.org/@types/node-forge/-/node-forge-1.3.11.tgz", + "integrity": "sha512-FQx220y22OKNTqaByeBGqHWYz4cl94tpcxeFdvBo3wjG6XPBuZ0BNgNZRV5J5TFmmcsJ4IzsLkmGRiQbnYsBEQ==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/qs": { + "version": "6.9.15", + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.15.tgz", + "integrity": "sha512-uXHQKES6DQKKCLh441Xv/dwxOq1TVS3JPUMlEqoEglvlhR6Mxnlew/Xq/LRVHpLyk7iK3zODe1qYHIMltO7XGg==", + "dev": true + }, + "node_modules/@types/range-parser": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.7.tgz", + "integrity": "sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==", + "dev": true + }, + "node_modules/@types/retry": { + "version": "0.12.2", + "resolved": "https://registry.npmjs.org/@types/retry/-/retry-0.12.2.tgz", + "integrity": "sha512-XISRgDJ2Tc5q4TRqvgJtzsRkFYNJzZrhTdtMoGVBttwzzQJkPnS3WWTFc7kuDRoPtPakl+T+OfdEUjYJj7Jbow==", + "dev": true + }, + "node_modules/@types/send": { + "version": "0.17.4", + "resolved": "https://registry.npmjs.org/@types/send/-/send-0.17.4.tgz", + "integrity": "sha512-x2EM6TJOybec7c52BX0ZspPodMsQUd5L6PRwOunVyVUhXiBSKf3AezDL8Dgvgt5o0UfKNfuA0eMLr2wLT4AiBA==", + "dev": true, + "dependencies": { + "@types/mime": "^1", + "@types/node": "*" + } + }, + "node_modules/@types/serve-index": { + "version": "1.9.4", + "resolved": "https://registry.npmjs.org/@types/serve-index/-/serve-index-1.9.4.tgz", + "integrity": "sha512-qLpGZ/c2fhSs5gnYsQxtDEq3Oy8SXPClIXkW5ghvAvsNuVSA8k+gCONcUCS/UjLEYvYps+e8uBtfgXgvhwfNug==", + "dev": true, + "dependencies": { + "@types/express": "*" + } + }, + "node_modules/@types/serve-static": { + "version": "1.15.7", + "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.7.tgz", + "integrity": "sha512-W8Ym+h8nhuRwaKPaDw34QUkwsGi6Rc4yYqvKFo5rm2FUEhCFbzVWrxXUxuKK8TASjWsysJY0nsmNCGhCOIsrOw==", + "dev": true, + "dependencies": { + "@types/http-errors": "*", + "@types/node": "*", + "@types/send": "*" + } + }, + "node_modules/@types/sockjs": { + "version": "0.3.36", + "resolved": "https://registry.npmjs.org/@types/sockjs/-/sockjs-0.3.36.tgz", + "integrity": "sha512-MK9V6NzAS1+Ud7JV9lJLFqW85VbC9dq3LmwZCuBe4wBDgKC0Kj/jd8Xl+nSviU+Qc3+m7umHHyHg//2KSa0a0Q==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/wrap-ansi": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@types/wrap-ansi/-/wrap-ansi-3.0.0.tgz", + "integrity": "sha512-ltIpx+kM7g/MLRZfkbL7EsCEjfzCcScLpkg37eXEtx5kmrAKBkTJwd1GIAjDSL8wTpM6Hzn5YO4pSb91BEwu1g==", + "dev": true + }, + "node_modules/@types/ws": { + "version": "8.5.11", + "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.11.tgz", + "integrity": "sha512-4+q7P5h3SpJxaBft0Dzpbr6lmMaqh0Jr2tbhJZ/luAwvD7ohSCniYkwz/pLxuT2h0EOa6QADgJj1Ko+TzRfZ+w==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@vitejs/plugin-basic-ssl": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@vitejs/plugin-basic-ssl/-/plugin-basic-ssl-1.1.0.tgz", + "integrity": "sha512-wO4Dk/rm8u7RNhOf95ZzcEmC9rYOncYgvq4z3duaJrCgjN8BxAnDVyndanfcJZ0O6XZzHz6Q0hTimxTg8Y9g/A==", + "dev": true, + "engines": { + "node": ">=14.6.0" + }, + "peerDependencies": { + "vite": "^3.0.0 || ^4.0.0 || ^5.0.0" + } + }, + "node_modules/@webassemblyjs/ast": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.12.1.tgz", + "integrity": "sha512-EKfMUOPRRUTy5UII4qJDGPpqfwjOmZ5jeGFwid9mnoqIFK+e0vqoi1qH56JpmZSzEL53jKnNzScdmftJyG5xWg==", + "dev": true, + "dependencies": { + "@webassemblyjs/helper-numbers": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6" + } + }, + "node_modules/@webassemblyjs/floating-point-hex-parser": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.6.tgz", + "integrity": "sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-api-error": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.6.tgz", + "integrity": "sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-buffer": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.12.1.tgz", + "integrity": "sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-numbers": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.6.tgz", + "integrity": "sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==", + "dev": true, + "dependencies": { + "@webassemblyjs/floating-point-hex-parser": "1.11.6", + "@webassemblyjs/helper-api-error": "1.11.6", + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@webassemblyjs/helper-wasm-bytecode": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.6.tgz", + "integrity": "sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-wasm-section": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.12.1.tgz", + "integrity": "sha512-Jif4vfB6FJlUlSbgEMHUyk1j234GTNG9dBJ4XJdOySoj518Xj0oGsNi59cUQF4RRMS9ouBUxDDdyBVfPTypa5g==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-buffer": "1.12.1", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/wasm-gen": "1.12.1" + } + }, + "node_modules/@webassemblyjs/ieee754": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.6.tgz", + "integrity": "sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==", + "dev": true, + "dependencies": { + "@xtuc/ieee754": "^1.2.0" + } + }, + "node_modules/@webassemblyjs/leb128": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.6.tgz", + "integrity": "sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==", + "dev": true, + "dependencies": { + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@webassemblyjs/utf8": { + "version": "1.11.6", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.6.tgz", + "integrity": "sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==", + "dev": true + }, + "node_modules/@webassemblyjs/wasm-edit": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.12.1.tgz", + "integrity": "sha512-1DuwbVvADvS5mGnXbE+c9NfA8QRcZ6iKquqjjmR10k6o+zzsRVesil54DKexiowcFCPdr/Q0qaMgB01+SQ1u6g==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-buffer": "1.12.1", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/helper-wasm-section": "1.12.1", + "@webassemblyjs/wasm-gen": "1.12.1", + "@webassemblyjs/wasm-opt": "1.12.1", + "@webassemblyjs/wasm-parser": "1.12.1", + "@webassemblyjs/wast-printer": "1.12.1" + } + }, + "node_modules/@webassemblyjs/wasm-gen": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.12.1.tgz", + "integrity": "sha512-TDq4Ojh9fcohAw6OIMXqiIcTq5KUXTGRkVxbSo1hQnSy6lAM5GSdfwWeSxpAo0YzgsgF182E/U0mDNhuA0tW7w==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" + } + }, + "node_modules/@webassemblyjs/wasm-opt": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.12.1.tgz", + "integrity": "sha512-Jg99j/2gG2iaz3hijw857AVYekZe2SAskcqlWIZXjji5WStnOpVoat3gQfT/Q5tb2djnCjBtMocY/Su1GfxPBg==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-buffer": "1.12.1", + "@webassemblyjs/wasm-gen": "1.12.1", + "@webassemblyjs/wasm-parser": "1.12.1" + } + }, + "node_modules/@webassemblyjs/wasm-parser": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.12.1.tgz", + "integrity": "sha512-xikIi7c2FHXysxXe3COrVUPSheuBtpcfhbpFj4gmu7KRLYOzANztwUU0IbsqvMqzuNK2+glRGWCEqZo1WCLyAQ==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/helper-api-error": "1.11.6", + "@webassemblyjs/helper-wasm-bytecode": "1.11.6", + "@webassemblyjs/ieee754": "1.11.6", + "@webassemblyjs/leb128": "1.11.6", + "@webassemblyjs/utf8": "1.11.6" + } + }, + "node_modules/@webassemblyjs/wast-printer": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.12.1.tgz", + "integrity": "sha512-+X4WAlOisVWQMikjbcvY2e0rwPsKQ9F688lksZhBcPycBBuii3O7m8FACbDMWDojpAqvjIncrG8J0XHKyQfVeA==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.12.1", + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@xtuc/ieee754": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", + "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==", + "dev": true + }, + "node_modules/@xtuc/long": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", + "dev": true + }, + "node_modules/@yarnpkg/lockfile": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz", + "integrity": "sha512-GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ==", + "dev": true + }, + "node_modules/abbrev": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-2.0.0.tgz", + "integrity": "sha512-6/mh1E2u2YgEsCHdY0Yx5oW+61gZU+1vXaoiHHrpKeuRNNgFvS+/jrwHiQhB5apAf5oB7UB7E19ol2R2LKH8hQ==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/accepts": { + "version": "1.3.8", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", + "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", + "dev": true, + "dependencies": { + "mime-types": "~2.1.34", + "negotiator": "0.6.3" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/acorn": { + "version": "8.12.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", + "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-import-attributes": { + "version": "1.9.5", + "resolved": "https://registry.npmjs.org/acorn-import-attributes/-/acorn-import-attributes-1.9.5.tgz", + "integrity": "sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==", + "dev": true, + "peerDependencies": { + "acorn": "^8" + } + }, + "node_modules/adjust-sourcemap-loader": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/adjust-sourcemap-loader/-/adjust-sourcemap-loader-4.0.0.tgz", + "integrity": "sha512-OXwN5b9pCUXNQHJpwwD2qP40byEmSgzj8B4ydSN0uMNYWiFmJ6x6KwUllMmfk8Rwu/HJDFR7U8ubsWBoN0Xp0A==", + "dev": true, + "dependencies": { + "loader-utils": "^2.0.0", + "regex-parser": "^2.2.11" + }, + "engines": { + "node": ">=8.9" + } + }, + "node_modules/adjust-sourcemap-loader/node_modules/loader-utils": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz", + "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==", + "dev": true, + "dependencies": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^2.1.2" + }, + "engines": { + "node": ">=8.9.0" + } + }, + "node_modules/agent-base": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", + "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", + "dev": true, + "dependencies": { + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/aggregate-error": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", + "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", + "dev": true, + "dependencies": { + "clean-stack": "^2.0.0", + "indent-string": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/ajv": { + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.16.0.tgz", + "integrity": "sha512-F0twR8U1ZU67JIEtekUcLkXkoO5mMMmgGD8sK/xUFzJ805jxHQl92hImFAqqXMyMYjSPOyUPAwHYhB72g5sTXw==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.3", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2", + "uri-js": "^4.4.1" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ajv-formats": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/ajv-formats/-/ajv-formats-3.0.1.tgz", + "integrity": "sha512-8iUql50EUR+uUcdRQ3HDqa6EVyo3docL8g5WJ3FNcWmu62IbkGUue/pEyLBW8VGKKucTPgqeks4fIU1DA4yowQ==", + "dev": true, + "dependencies": { + "ajv": "^8.0.0" + }, + "peerDependencies": { + "ajv": "^8.0.0" + }, + "peerDependenciesMeta": { + "ajv": { + "optional": true + } + } + }, + "node_modules/ajv-keywords": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz", + "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.3" + }, + "peerDependencies": { + "ajv": "^8.8.2" + } + }, + "node_modules/ansi-colors": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", + "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", + "dev": true, + "dependencies": { + "type-fest": "^0.21.3" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ansi-html-community": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/ansi-html-community/-/ansi-html-community-0.0.8.tgz", + "integrity": "sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==", + "dev": true, + "engines": [ + "node >= 0.8.0" + ], + "bin": { + "ansi-html": "bin/ansi-html" + } + }, + "node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "dev": true, + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/anymatch/node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/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/array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==", + "dev": true + }, + "node_modules/autoprefixer": { + "version": "10.4.19", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.19.tgz", + "integrity": "sha512-BaENR2+zBZ8xXhM4pUaKUxlVdxZ0EZhjvbopwnXmxRUfqDmwSpC2lAi/QXvx7NRdPCo1WKEcEF6mV64si1z4Ew==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/autoprefixer" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "browserslist": "^4.23.0", + "caniuse-lite": "^1.0.30001599", + "fraction.js": "^4.3.7", + "normalize-range": "^0.1.2", + "picocolors": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "bin": { + "autoprefixer": "bin/autoprefixer" + }, + "engines": { + "node": "^10 || ^12 || >=14" + }, + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/babel-loader": { + "version": "9.1.3", + "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-9.1.3.tgz", + "integrity": "sha512-xG3ST4DglodGf8qSwv0MdeWLhrDsw/32QMdTO5T1ZIp9gQur0HkCyFs7Awskr10JKXFXwpAhiCuYX5oGXnRGbw==", + "dev": true, + "dependencies": { + "find-cache-dir": "^4.0.0", + "schema-utils": "^4.0.0" + }, + "engines": { + "node": ">= 14.15.0" + }, + "peerDependencies": { + "@babel/core": "^7.12.0", + "webpack": ">=5" + } + }, + "node_modules/babel-plugin-polyfill-corejs2": { + "version": "0.4.11", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.11.tgz", + "integrity": "sha512-sMEJ27L0gRHShOh5G54uAAPaiCOygY/5ratXuiyb2G46FmlSpc9eFCzYVyDiPxfNbwzA7mYahmjQc5q+CZQ09Q==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.22.6", + "@babel/helper-define-polyfill-provider": "^0.6.2", + "semver": "^6.3.1" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/babel-plugin-polyfill-corejs2/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/babel-plugin-polyfill-corejs3": { + "version": "0.10.4", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.10.4.tgz", + "integrity": "sha512-25J6I8NGfa5YkCDogHRID3fVCadIR8/pGl1/spvCkzb6lVn6SR3ojpx9nOn9iEBcUsjY24AmdKm5khcfKdylcg==", + "dev": true, + "dependencies": { + "@babel/helper-define-polyfill-provider": "^0.6.1", + "core-js-compat": "^3.36.1" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/babel-plugin-polyfill-regenerator": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.6.2.tgz", + "integrity": "sha512-2R25rQZWP63nGwaAswvDazbPXfrM3HwVoBXK6HcqeKrSrL/JqcC/rDcf95l4r7LXLyxDXc8uQDa064GubtCABg==", + "dev": true, + "dependencies": { + "@babel/helper-define-polyfill-provider": "^0.6.2" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "node_modules/base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", + "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", + "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/base64id": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", + "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==", + "dev": true, + "engines": { + "node": "^4.5.0 || >= 5.9" + } + }, + "node_modules/batch": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz", + "integrity": "sha512-x+VAiMRL6UPkx+kudNvxTl6hB2XNNCG2r+7wixVfIYwu/2HKRXimwQyaumLjMveWvT2Hkd/cAJw+QBMfJ/EKVw==", + "dev": true + }, + "node_modules/big.js": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", + "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", + "dev": true, + "engines": { + "node": "*" + } + }, + "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==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/bl": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", + "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", + "dev": true, + "dependencies": { + "buffer": "^5.5.0", + "inherits": "^2.0.4", + "readable-stream": "^3.4.0" + } + }, + "node_modules/body-parser": { + "version": "1.20.2", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz", + "integrity": "sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==", + "dev": true, + "dependencies": { + "bytes": "3.1.2", + "content-type": "~1.0.5", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.11.0", + "raw-body": "2.5.2", + "type-is": "~1.6.18", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/body-parser/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/body-parser/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/bonjour-service": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/bonjour-service/-/bonjour-service-1.2.1.tgz", + "integrity": "sha512-oSzCS2zV14bh2kji6vNe7vrpJYCHGvcZnlffFQ1MEoX/WOeQ/teD8SYWKR942OI3INjq8OMNJlbPK5LLLUxFDw==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.3", + "multicast-dns": "^7.2.5" + } + }, + "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.3", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", + "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", + "dev": true, + "dependencies": { + "fill-range": "^7.1.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/browserslist": { + "version": "4.23.2", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.2.tgz", + "integrity": "sha512-qkqSyistMYdxAcw+CzbZwlBy8AGmS/eEWs+sEV5TnLRGDOL+C5M2EnH6tlZyg0YoAxGJAFKh61En9BR941GnHA==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "caniuse-lite": "^1.0.30001640", + "electron-to-chromium": "^1.4.820", + "node-releases": "^2.0.14", + "update-browserslist-db": "^1.1.0" + }, + "bin": { + "browserslist": "cli.js" + }, + "engines": { + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" + } + }, + "node_modules/buffer": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", + "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", + "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": { + "base64-js": "^1.3.1", + "ieee754": "^1.1.13" + } + }, + "node_modules/buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", + "dev": true + }, + "node_modules/bundle-name": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/bundle-name/-/bundle-name-4.1.0.tgz", + "integrity": "sha512-tjwM5exMg6BGRI+kNmTntNsvdZS1X8BFYS6tnJ2hdH0kVxM6/eVZ2xy+FqStSWvYmtfFMDLIxurorHwDKfDz5Q==", + "dev": true, + "dependencies": { + "run-applescript": "^7.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/cacache": { + "version": "18.0.4", + "resolved": "https://registry.npmjs.org/cacache/-/cacache-18.0.4.tgz", + "integrity": "sha512-B+L5iIa9mgcjLbliir2th36yEwPftrzteHYujzsx3dFP/31GCHcIeS8f5MGd80odLOjaOvSpU3EEAmRQptkxLQ==", + "dev": true, + "dependencies": { + "@npmcli/fs": "^3.1.0", + "fs-minipass": "^3.0.0", + "glob": "^10.2.2", + "lru-cache": "^10.0.1", + "minipass": "^7.0.3", + "minipass-collect": "^2.0.1", + "minipass-flush": "^1.0.5", + "minipass-pipeline": "^1.2.4", + "p-map": "^4.0.0", + "ssri": "^10.0.0", + "tar": "^6.1.11", + "unique-filename": "^3.0.0" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/cacache/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/cacache/node_modules/glob": { + "version": "10.4.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", + "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", + "dev": true, + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^3.1.2", + "minimatch": "^9.0.4", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^1.11.1" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/cacache/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", + "dev": true + }, + "node_modules/cacache/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "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/caniuse-lite": { + "version": "1.0.30001642", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001642.tgz", + "integrity": "sha512-3XQ0DoRgLijXJErLSl+bLnJ+Et4KqV1PY6JJBGAFlsNsz31zeAIncyeZfLCabHK/jtSh+671RM9YMldxjUPZtA==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ] + }, + "node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", + "dev": true + }, + "node_modules/chokidar": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", + "dev": 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/chownr": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", + "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/chrome-trace-event": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.4.tgz", + "integrity": "sha512-rNjApaLzuwaOTjCiT8lSDdGN1APCiqkChLMJxJPWLunPAt5fy8xgU9/jNOchV84wfIxrA0lRQB7oCT8jrn/wrQ==", + "dev": true, + "engines": { + "node": ">=6.0" + } + }, + "node_modules/clean-stack": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", + "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/cli-cursor": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-4.0.0.tgz", + "integrity": "sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg==", + "dev": true, + "dependencies": { + "restore-cursor": "^4.0.0" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cli-spinners": { + "version": "2.9.2", + "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.9.2.tgz", + "integrity": "sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==", + "dev": true, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cli-truncate": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-4.0.0.tgz", + "integrity": "sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==", + "dev": true, + "dependencies": { + "slice-ansi": "^5.0.0", + "string-width": "^7.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cli-width": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-4.1.0.tgz", + "integrity": "sha512-ouuZd4/dm2Sw5Gmqy6bGyNNNe1qt9RpmxveLSO7KcgsTnU7RXfsw+/bukWGo1abgBiMAic068rclZsO4IWmmxQ==", + "dev": true, + "engines": { + "node": ">= 12" + } + }, + "node_modules/cliui": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", + "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", + "dev": true, + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/cliui/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/cliui/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/cliui/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/cliui/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/cliui/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/clone": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", + "integrity": "sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==", + "dev": true, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/clone-deep": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", + "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", + "dev": true, + "dependencies": { + "is-plain-object": "^2.0.4", + "kind-of": "^6.0.2", + "shallow-clone": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "node_modules/colorette": { + "version": "2.0.20", + "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz", + "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==", + "dev": true + }, + "node_modules/commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", + "dev": true + }, + "node_modules/common-path-prefix": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/common-path-prefix/-/common-path-prefix-3.0.0.tgz", + "integrity": "sha512-QE33hToZseCH3jS0qN96O/bSh3kaw/h+Tq7ngyY9eWDUnTlTNUyqfqvCXioLe5Na5jFsL78ra/wuBU4iuEgd4w==", + "dev": true + }, + "node_modules/compressible": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", + "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", + "dev": true, + "dependencies": { + "mime-db": ">= 1.43.0 < 2" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/compression": { + "version": "1.7.4", + "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", + "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", + "dev": true, + "dependencies": { + "accepts": "~1.3.5", + "bytes": "3.0.0", + "compressible": "~2.0.16", + "debug": "2.6.9", + "on-headers": "~1.0.2", + "safe-buffer": "5.1.2", + "vary": "~1.1.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/compression/node_modules/bytes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", + "integrity": "sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/compression/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/compression/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/compression/node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": 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/connect": { + "version": "3.7.0", + "resolved": "https://registry.npmjs.org/connect/-/connect-3.7.0.tgz", + "integrity": "sha512-ZqRXc+tZukToSNmh5C2iWMSoV3X1YUcPbqEM4DkEG5tNQXrQUZCNVGGv3IuicnkMtPfGf3Xtp8WCXs295iQ1pQ==", + "dev": true, + "dependencies": { + "debug": "2.6.9", + "finalhandler": "1.1.2", + "parseurl": "~1.3.3", + "utils-merge": "1.0.1" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/connect-history-api-fallback": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-2.0.0.tgz", + "integrity": "sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA==", + "dev": true, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/connect/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/connect/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/content-disposition": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", + "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", + "dev": true, + "dependencies": { + "safe-buffer": "5.2.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/content-type": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", + "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/convert-source-map": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", + "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "dev": true + }, + "node_modules/cookie": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", + "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==", + "dev": true + }, + "node_modules/copy-anything": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/copy-anything/-/copy-anything-2.0.6.tgz", + "integrity": "sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==", + "dev": true, + "dependencies": { + "is-what": "^3.14.1" + }, + "funding": { + "url": "https://github.com/sponsors/mesqueeb" + } + }, + "node_modules/copy-webpack-plugin": { + "version": "12.0.2", + "resolved": "https://registry.npmjs.org/copy-webpack-plugin/-/copy-webpack-plugin-12.0.2.tgz", + "integrity": "sha512-SNwdBeHyII+rWvee/bTnAYyO8vfVdcSTud4EIb6jcZ8inLeWucJE0DnxXQBjlQ5zlteuuvooGQy3LIyGxhvlOA==", + "dev": true, + "dependencies": { + "fast-glob": "^3.3.2", + "glob-parent": "^6.0.1", + "globby": "^14.0.0", + "normalize-path": "^3.0.0", + "schema-utils": "^4.2.0", + "serialize-javascript": "^6.0.2" + }, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^5.1.0" + } + }, + "node_modules/copy-webpack-plugin/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/core-js-compat": { + "version": "3.37.1", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.37.1.tgz", + "integrity": "sha512-9TNiImhKvQqSUkOvk/mMRZzOANTiEVC7WaBNhHcKM7x+/5E1l5NvsysR19zuDQScE8k+kfQXWRN3AtS/eOSHpg==", + "dev": true, + "dependencies": { + "browserslist": "^4.23.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/core-js" + } + }, + "node_modules/core-util-is": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", + "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", + "dev": true + }, + "node_modules/cors": { + "version": "2.8.5", + "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", + "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", + "dev": true, + "dependencies": { + "object-assign": "^4", + "vary": "^1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/cosmiconfig": { + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-9.0.0.tgz", + "integrity": "sha512-itvL5h8RETACmOTFc4UfIyB2RfEHi71Ax6E/PivVxq9NseKbOWpeyHEOIbmAw1rs8Ak0VursQNww7lf7YtUwzg==", + "dev": true, + "dependencies": { + "env-paths": "^2.2.1", + "import-fresh": "^3.3.0", + "js-yaml": "^4.1.0", + "parse-json": "^5.2.0" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/d-fischer" + }, + "peerDependencies": { + "typescript": ">=4.9.5" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/critters": { + "version": "0.0.24", + "resolved": "https://registry.npmjs.org/critters/-/critters-0.0.24.tgz", + "integrity": "sha512-Oyqew0FGM0wYUSNqR0L6AteO5MpMoUU0rhKRieXeiKs+PmRTxiJMyaunYB2KF6fQ3dzChXKCpbFOEJx3OQ1v/Q==", + "dev": true, + "dependencies": { + "chalk": "^4.1.0", + "css-select": "^5.1.0", + "dom-serializer": "^2.0.0", + "domhandler": "^5.0.2", + "htmlparser2": "^8.0.2", + "postcss": "^8.4.23", + "postcss-media-query-parser": "^0.2.3" + } + }, + "node_modules/critters/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/critters/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/critters/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/critters/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/critters/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/critters/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/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/cross-spawn/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/css-loader": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-7.1.2.tgz", + "integrity": "sha512-6WvYYn7l/XEGN8Xu2vWFt9nVzrCn39vKyTEFf/ExEyoksJjjSZV/0/35XPlMbpnr6VGhZIUg5yJrL8tGfes/FA==", + "dev": true, + "dependencies": { + "icss-utils": "^5.1.0", + "postcss": "^8.4.33", + "postcss-modules-extract-imports": "^3.1.0", + "postcss-modules-local-by-default": "^4.0.5", + "postcss-modules-scope": "^3.2.0", + "postcss-modules-values": "^4.0.0", + "postcss-value-parser": "^4.2.0", + "semver": "^7.5.4" + }, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "@rspack/core": "0.x || 1.x", + "webpack": "^5.27.0" + }, + "peerDependenciesMeta": { + "@rspack/core": { + "optional": true + }, + "webpack": { + "optional": true + } + } + }, + "node_modules/css-select": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-5.1.0.tgz", + "integrity": "sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==", + "dev": true, + "dependencies": { + "boolbase": "^1.0.0", + "css-what": "^6.1.0", + "domhandler": "^5.0.2", + "domutils": "^3.0.1", + "nth-check": "^2.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/fb55" + } + }, + "node_modules/css-what": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz", + "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==", + "dev": true, + "engines": { + "node": ">= 6" + }, + "funding": { + "url": "https://github.com/sponsors/fb55" + } + }, + "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/custom-event": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/custom-event/-/custom-event-1.0.1.tgz", + "integrity": "sha512-GAj5FOq0Hd+RsCGVJxZuKaIDXDf3h6GQoNEjFgbLLI/trgtavwUbSnZ5pVfg27DVCaWjIohryS0JFwIJyT2cMg==", + "dev": true + }, + "node_modules/date-format": { + "version": "4.0.14", + "resolved": "https://registry.npmjs.org/date-format/-/date-format-4.0.14.tgz", + "integrity": "sha512-39BOQLs9ZjKh0/patS9nrT8wc3ioX3/eA/zgbKNopnF2wCqJEoxywwwElATYvRsXdnOxA/OQeQoFZ3rFjVajhg==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/debug": { + "version": "4.3.5", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.5.tgz", + "integrity": "sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/default-browser": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/default-browser/-/default-browser-5.2.1.tgz", + "integrity": "sha512-WY/3TUME0x3KPYdRRxEJJvXRHV4PyPoUsxtZa78lwItwRQRHhd2U9xOscaT/YTf8uCXIAjeJOFBVEh/7FtD8Xg==", + "dev": true, + "dependencies": { + "bundle-name": "^4.1.0", + "default-browser-id": "^5.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/default-browser-id": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/default-browser-id/-/default-browser-id-5.0.0.tgz", + "integrity": "sha512-A6p/pu/6fyBcA1TRz/GqWYPViplrftcW2gZC9q79ngNCKAeR/X3gcEdXQHl4KNXV+3wgIJ1CPkJQ3IHM6lcsyA==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/default-gateway": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-6.0.3.tgz", + "integrity": "sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg==", + "dev": true, + "dependencies": { + "execa": "^5.0.0" + }, + "engines": { + "node": ">= 10" + } + }, + "node_modules/defaults": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.4.tgz", + "integrity": "sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A==", + "dev": true, + "dependencies": { + "clone": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/define-lazy-prop": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-3.0.0.tgz", + "integrity": "sha512-N+MeXYoqr3pOgn8xfyRPREN7gHakLYjhsHhWGT3fWAiL4IkAt0iDw14QiiEm2bE30c5XX5q0FtAA3CK5f9/BUg==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/destroy": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", + "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", + "dev": true, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/detect-libc": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.3.tgz", + "integrity": "sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/detect-node": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz", + "integrity": "sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==", + "dev": true + }, + "node_modules/di": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/di/-/di-0.0.1.tgz", + "integrity": "sha512-uJaamHkagcZtHPqCIHZxnFrXlunQXgBOsZSUOWwFw31QJCAbyTBoHMW75YOTur5ZNx8pIeAKgf6GWIgaqqiLhA==", + "dev": true + }, + "node_modules/dns-packet": { + "version": "5.6.1", + "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-5.6.1.tgz", + "integrity": "sha512-l4gcSouhcgIKRvyy99RNVOgxXiicE+2jZoNmaNmZ6JXiGajBOJAesk1OBlJuM5k2c+eudGdLxDqXuPCKIj6kpw==", + "dev": true, + "dependencies": { + "@leichtgewicht/ip-codec": "^2.0.1" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/dom-serialize": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/dom-serialize/-/dom-serialize-2.2.1.tgz", + "integrity": "sha512-Yra4DbvoW7/Z6LBN560ZwXMjoNOSAN2wRsKFGc4iBeso+mpIA6qj1vfdf9HpMaKAqG6wXTy+1SYEzmNpKXOSsQ==", + "dev": true, + "dependencies": { + "custom-event": "~1.0.0", + "ent": "~2.2.0", + "extend": "^3.0.0", + "void-elements": "^2.0.0" + } + }, + "node_modules/dom-serializer": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-2.0.0.tgz", + "integrity": "sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==", + "dev": true, + "dependencies": { + "domelementtype": "^2.3.0", + "domhandler": "^5.0.2", + "entities": "^4.2.0" + }, + "funding": { + "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" + } + }, + "node_modules/domelementtype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", + "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/fb55" + } + ] + }, + "node_modules/domhandler": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-5.0.3.tgz", + "integrity": "sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==", + "dev": true, + "dependencies": { + "domelementtype": "^2.3.0" + }, + "engines": { + "node": ">= 4" + }, + "funding": { + "url": "https://github.com/fb55/domhandler?sponsor=1" + } + }, + "node_modules/domutils": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-3.1.0.tgz", + "integrity": "sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA==", + "dev": true, + "dependencies": { + "dom-serializer": "^2.0.0", + "domelementtype": "^2.3.0", + "domhandler": "^5.0.3" + }, + "funding": { + "url": "https://github.com/fb55/domutils?sponsor=1" + } + }, + "node_modules/eastasianwidth": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", + "dev": true + }, + "node_modules/ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", + "dev": true + }, + "node_modules/electron-to-chromium": { + "version": "1.4.827", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.827.tgz", + "integrity": "sha512-VY+J0e4SFcNfQy19MEoMdaIcZLmDCprqvBtkii1WTCTQHpRvf5N8+3kTYCgL/PcntvwQvmMJWTuDPsq+IlhWKQ==", + "dev": true + }, + "node_modules/emoji-regex": { + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.3.0.tgz", + "integrity": "sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==", + "dev": true + }, + "node_modules/emojis-list": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz", + "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", + "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/encoding": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz", + "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==", + "dev": true, + "optional": true, + "dependencies": { + "iconv-lite": "^0.6.2" + } + }, + "node_modules/encoding/node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "dev": true, + "optional": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/engine.io": { + "version": "6.5.5", + "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-6.5.5.tgz", + "integrity": "sha512-C5Pn8Wk+1vKBoHghJODM63yk8MvrO9EWZUfkAt5HAqIgPE4/8FF0PEGHXtEd40l223+cE5ABWuPzm38PHFXfMA==", + "dev": true, + "dependencies": { + "@types/cookie": "^0.4.1", + "@types/cors": "^2.8.12", + "@types/node": ">=10.0.0", + "accepts": "~1.3.4", + "base64id": "2.0.0", + "cookie": "~0.4.1", + "cors": "~2.8.5", + "debug": "~4.3.1", + "engine.io-parser": "~5.2.1", + "ws": "~8.17.1" + }, + "engines": { + "node": ">=10.2.0" + } + }, + "node_modules/engine.io-parser": { + "version": "5.2.3", + "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.2.3.tgz", + "integrity": "sha512-HqD3yTBfnBxIrbnM1DoD6Pcq8NECnh8d4As1Qgh0z5Gg3jRRIqijury0CL3ghu/edArpUYiYqQiDUQBIs4np3Q==", + "dev": true, + "engines": { + "node": ">=10.0.0" + } + }, + "node_modules/enhanced-resolve": { + "version": "5.17.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.17.0.tgz", + "integrity": "sha512-dwDPwZL0dmye8Txp2gzFmA6sxALaSvdRDjPH0viLcKrtlOL3tw62nWWweVD1SdILDTJrbrL6tdWVN58Wo6U3eA==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.2.4", + "tapable": "^2.2.0" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/ent": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ent/-/ent-2.2.1.tgz", + "integrity": "sha512-QHuXVeZx9d+tIQAz/XztU0ZwZf2Agg9CcXcgE1rurqvdBeDBrpSwjl8/6XUqMg7tw2Y7uAdKb2sRv+bSEFqQ5A==", + "dev": true, + "dependencies": { + "punycode": "^1.4.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/entities": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", + "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", + "dev": true, + "engines": { + "node": ">=0.12" + }, + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, + "node_modules/env-paths": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz", + "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/err-code": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/err-code/-/err-code-2.0.3.tgz", + "integrity": "sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA==", + "dev": true + }, + "node_modules/errno": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.8.tgz", + "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==", + "dev": true, + "optional": true, + "dependencies": { + "prr": "~1.0.1" + }, + "bin": { + "errno": "cli.js" + } + }, + "node_modules/error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "dependencies": { + "is-arrayish": "^0.2.1" + } + }, + "node_modules/es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-module-lexer": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.5.4.tgz", + "integrity": "sha512-MVNK56NiMrOwitFB7cqDwq0CQutbw+0BvLshJSse0MUNU+y1FC3bUS/AQg7oUng+/wKrrki7JfmwtVHkVfPLlw==", + "dev": true + }, + "node_modules/esbuild": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz", + "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==", + "dev": true, + "hasInstallScript": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + }, + "optionalDependencies": { + "@esbuild/aix-ppc64": "0.21.5", + "@esbuild/android-arm": "0.21.5", + "@esbuild/android-arm64": "0.21.5", + "@esbuild/android-x64": "0.21.5", + "@esbuild/darwin-arm64": "0.21.5", + "@esbuild/darwin-x64": "0.21.5", + "@esbuild/freebsd-arm64": "0.21.5", + "@esbuild/freebsd-x64": "0.21.5", + "@esbuild/linux-arm": "0.21.5", + "@esbuild/linux-arm64": "0.21.5", + "@esbuild/linux-ia32": "0.21.5", + "@esbuild/linux-loong64": "0.21.5", + "@esbuild/linux-mips64el": "0.21.5", + "@esbuild/linux-ppc64": "0.21.5", + "@esbuild/linux-riscv64": "0.21.5", + "@esbuild/linux-s390x": "0.21.5", + "@esbuild/linux-x64": "0.21.5", + "@esbuild/netbsd-x64": "0.21.5", + "@esbuild/openbsd-x64": "0.21.5", + "@esbuild/sunos-x64": "0.21.5", + "@esbuild/win32-arm64": "0.21.5", + "@esbuild/win32-ia32": "0.21.5", + "@esbuild/win32-x64": "0.21.5" + } + }, + "node_modules/esbuild-wasm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/esbuild-wasm/-/esbuild-wasm-0.21.5.tgz", + "integrity": "sha512-L/FlOPMMFtw+6qPAbuPvJXdrOYOp9yx/PEwSrIZW0qghY4vgV003evdYDwqQ/9ENMQI0B6RMod9xT4FHtto6OQ==", + "dev": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/escalade": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", + "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==", + "dev": true + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "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/esrecurse/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/estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "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/etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/eventemitter3": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", + "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==", + "dev": true + }, + "node_modules/events": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", + "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", + "dev": true, + "engines": { + "node": ">=0.8.x" + } + }, + "node_modules/execa": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", + "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", + "dev": true, + "dependencies": { + "cross-spawn": "^7.0.3", + "get-stream": "^6.0.0", + "human-signals": "^2.1.0", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.1", + "onetime": "^5.1.2", + "signal-exit": "^3.0.3", + "strip-final-newline": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sindresorhus/execa?sponsor=1" + } + }, + "node_modules/execa/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + }, + "node_modules/exponential-backoff": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/exponential-backoff/-/exponential-backoff-3.1.1.tgz", + "integrity": "sha512-dX7e/LHVJ6W3DE1MHWi9S1EYzDESENfLrYohG2G++ovZrYOkm4Knwa0mc1cn84xJOR4KEU0WSchhLbd0UklbHw==", + "dev": true + }, + "node_modules/express": { + "version": "4.19.2", + "resolved": "https://registry.npmjs.org/express/-/express-4.19.2.tgz", + "integrity": "sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==", + "dev": true, + "dependencies": { + "accepts": "~1.3.8", + "array-flatten": "1.1.1", + "body-parser": "1.20.2", + "content-disposition": "0.5.4", + "content-type": "~1.0.4", + "cookie": "0.6.0", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "2.0.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "1.2.0", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.7", + "proxy-addr": "~2.0.7", + "qs": "6.11.0", + "range-parser": "~1.2.1", + "safe-buffer": "5.2.1", + "send": "0.18.0", + "serve-static": "1.15.0", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/express/node_modules/cookie": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", + "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/express/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/express/node_modules/finalhandler": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", + "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", + "dev": true, + "dependencies": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "statuses": "2.0.1", + "unpipe": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/express/node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "dev": true + }, + "node_modules/external-editor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", + "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", + "dev": true, + "dependencies": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "node_modules/fast-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-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/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/faye-websocket": { + "version": "0.11.4", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz", + "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==", + "dev": true, + "dependencies": { + "websocket-driver": ">=0.5.1" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/fill-range": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", + "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", + "dev": true, + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/finalhandler": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", + "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", + "dev": true, + "dependencies": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "statuses": "~1.5.0", + "unpipe": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/finalhandler/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/finalhandler/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/finalhandler/node_modules/on-finished": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", + "integrity": "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==", + "dev": true, + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/find-cache-dir": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-4.0.0.tgz", + "integrity": "sha512-9ZonPT4ZAK4a+1pUPVPZJapbi7O5qbbJPdYw/NOQWZZbVLdDTYM3A4R9z/DpAM08IDaFGsvPgiGZ82WEwUDWjg==", + "dev": true, + "dependencies": { + "common-path-prefix": "^3.0.0", + "pkg-dir": "^7.0.0" + }, + "engines": { + "node": ">=14.16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/find-up": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-6.3.0.tgz", + "integrity": "sha512-v2ZsoEuVHYy8ZIlYqwPe/39Cy+cFDzp4dXPaxNvkEuouymu+2Jbz0PxpKarJHYJTmv2HWT3O382qY8l4jMWthw==", + "dev": true, + "dependencies": { + "locate-path": "^7.1.0", + "path-exists": "^5.0.0" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/flat": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", + "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", + "dev": true, + "bin": { + "flat": "cli.js" + } + }, + "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==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/foreground-child": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.2.1.tgz", + "integrity": "sha512-PXUUyLqrR2XCWICfv6ukppP96sdFwWbNEnfEMt7jNsISjMsvaLNinAHNDYyvkyU+SZG2BTSbT5NjG+vZslfGTA==", + "dev": true, + "dependencies": { + "cross-spawn": "^7.0.0", + "signal-exit": "^4.0.1" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fraction.js": { + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", + "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", + "dev": true, + "engines": { + "node": "*" + }, + "funding": { + "type": "patreon", + "url": "https://github.com/sponsors/rawify" + } + }, + "node_modules/fresh": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", + "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fs-extra": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", + "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.2.0", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + }, + "engines": { + "node": ">=6 <7 || >=8" + } + }, + "node_modules/fs-minipass": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-3.0.3.tgz", + "integrity": "sha512-XUBA9XClHbnJWSfBzjkm6RvPsyg3sryZt06BEQoXcF7EK/xpGaQYJgQKDJSUH5SGZ76Y7pFx1QBnXz09rU5Fbw==", + "dev": true, + "dependencies": { + "minipass": "^7.0.3" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "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==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true, + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-east-asian-width": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.2.0.tgz", + "integrity": "sha512-2nk+7SIVb14QrgXFHcm84tD4bKQz0RxPuMT8Ag5KPOq7J5fEmAg0UbXdTOSHqNuHSU28k55qnceesxXRZGzKWA==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-stream": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", + "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/glob-to-regexp": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", + "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", + "dev": true + }, + "node_modules/globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/globby": { + "version": "14.0.2", + "resolved": "https://registry.npmjs.org/globby/-/globby-14.0.2.tgz", + "integrity": "sha512-s3Fq41ZVh7vbbe2PN3nrW7yC7U7MFVc5c98/iTl9c2GawNMKx/J648KQRW6WKkuU8GIbbh2IXfIRQjOZnXcTnw==", + "dev": true, + "dependencies": { + "@sindresorhus/merge-streams": "^2.1.0", + "fast-glob": "^3.3.2", + "ignore": "^5.2.4", + "path-type": "^5.0.0", + "slash": "^5.1.0", + "unicorn-magic": "^0.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true + }, + "node_modules/handle-thing": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.1.tgz", + "integrity": "sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==", + "dev": true + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/hosted-git-info": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-7.0.2.tgz", + "integrity": "sha512-puUZAUKT5m8Zzvs72XWy3HtvVbTWljRE66cP60bxJzAqf2DgICo7lYTY2IHUmLnNpjYvw5bvmoHvPc0QO2a62w==", + "dev": true, + "dependencies": { + "lru-cache": "^10.0.1" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/hosted-git-info/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", + "dev": true + }, + "node_modules/hpack.js": { + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz", + "integrity": "sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ==", + "dev": true, + "dependencies": { + "inherits": "^2.0.1", + "obuf": "^1.0.0", + "readable-stream": "^2.0.1", + "wbuf": "^1.1.0" + } + }, + "node_modules/hpack.js/node_modules/readable-stream": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", + "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", + "dev": true, + "dependencies": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "node_modules/hpack.js/node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + }, + "node_modules/hpack.js/node_modules/string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "dependencies": { + "safe-buffer": "~5.1.0" + } + }, + "node_modules/html-entities": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-2.5.2.tgz", + "integrity": "sha512-K//PSRMQk4FZ78Kyau+mZurHn3FH0Vwr+H36eE0rPbeYkRRi9YxceYPhuN60UwWorxyKHhqoAJl2OFKa4BVtaA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/mdevils" + }, + { + "type": "patreon", + "url": "https://patreon.com/mdevils" + } + ] + }, + "node_modules/html-escaper": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", + "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", + "dev": true + }, + "node_modules/htmlparser2": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-8.0.2.tgz", + "integrity": "sha512-GYdjWKDkbRLkZ5geuHs5NY1puJ+PXwP7+fHPRz06Eirsb9ugf6d8kkXav6ADhcODhFFPMIXyxkxSuMf3D6NCFA==", + "dev": true, + "funding": [ + "https://github.com/fb55/htmlparser2?sponsor=1", + { + "type": "github", + "url": "https://github.com/sponsors/fb55" + } + ], + "dependencies": { + "domelementtype": "^2.3.0", + "domhandler": "^5.0.3", + "domutils": "^3.0.1", + "entities": "^4.4.0" + } + }, + "node_modules/http-cache-semantics": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", + "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==", + "dev": true + }, + "node_modules/http-deceiver": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz", + "integrity": "sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw==", + "dev": true + }, + "node_modules/http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "dev": true, + "dependencies": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/http-errors/node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/http-parser-js": { + "version": "0.5.8", + "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz", + "integrity": "sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==", + "dev": true + }, + "node_modules/http-proxy": { + "version": "1.18.1", + "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.1.tgz", + "integrity": "sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ==", + "dev": true, + "dependencies": { + "eventemitter3": "^4.0.0", + "follow-redirects": "^1.0.0", + "requires-port": "^1.0.0" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/http-proxy-agent": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", + "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", + "dev": true, + "dependencies": { + "agent-base": "^7.1.0", + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/http-proxy-middleware": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-3.0.0.tgz", + "integrity": "sha512-36AV1fIaI2cWRzHo+rbcxhe3M3jUDCNzc4D5zRl57sEWRAxdXYtw7FSQKYY6PDKssiAKjLYypbssHk+xs/kMXw==", + "dev": true, + "dependencies": { + "@types/http-proxy": "^1.17.10", + "debug": "^4.3.4", + "http-proxy": "^1.18.1", + "is-glob": "^4.0.1", + "is-plain-obj": "^3.0.0", + "micromatch": "^4.0.5" + }, + "engines": { + "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + } + }, + "node_modules/https-proxy-agent": { + "version": "7.0.5", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.5.tgz", + "integrity": "sha512-1e4Wqeblerz+tMKPIq2EMGiiWW1dIjZOksyHWSUm1rmuvw/how9hBHZ38lAGj5ID4Ik6EdkOw7NmWPy6LAwalw==", + "dev": true, + "dependencies": { + "agent-base": "^7.0.2", + "debug": "4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/human-signals": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", + "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", + "dev": true, + "engines": { + "node": ">=10.17.0" + } + }, + "node_modules/hyperdyperid": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/hyperdyperid/-/hyperdyperid-1.2.0.tgz", + "integrity": "sha512-Y93lCzHYgGWdrJ66yIktxiaGULYc6oGiABxhcO5AufBeOyoIdZF7bIfLaOrbM0iGIOXQQgxxRrFEnb+Y6w1n4A==", + "dev": true, + "engines": { + "node": ">=10.18" + } + }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/icss-utils": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz", + "integrity": "sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==", + "dev": true, + "engines": { + "node": "^10 || ^12 || >= 14" + }, + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/ieee754": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", + "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", + "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/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/ignore-walk": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-6.0.5.tgz", + "integrity": "sha512-VuuG0wCnjhnylG1ABXT3dAuIpTNDs/G8jlpmwXY03fXoXy/8ZK8/T+hMzt8L4WnrLCJgdybqgPagnF/f97cg3A==", + "dev": true, + "dependencies": { + "minimatch": "^9.0.0" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/ignore-walk/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/ignore-walk/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/image-size": { + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/image-size/-/image-size-0.5.5.tgz", + "integrity": "sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ==", + "dev": true, + "optional": true, + "bin": { + "image-size": "bin/image-size.js" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "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==", + "dev": 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/indent-string": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", + "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "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==", + "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", + "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/ini": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/ini/-/ini-4.1.3.tgz", + "integrity": "sha512-X7rqawQBvfdjS10YU1y1YVreA3SsLrW9dX2CewP2EbBJM4ypVNLDkO5y04gejPwKIY9lR+7r9gn3rFPt/kmWFg==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/ip-address": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/ip-address/-/ip-address-9.0.5.tgz", + "integrity": "sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==", + "dev": true, + "dependencies": { + "jsbn": "1.1.0", + "sprintf-js": "^1.1.3" + }, + "engines": { + "node": ">= 12" + } + }, + "node_modules/ipaddr.js": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-2.2.0.tgz", + "integrity": "sha512-Ag3wB2o37wslZS19hZqorUnrnzSkpOVy+IiiDEiTqNubEYpYuHWIf6K4psgN2ZWKExS4xhVCrRVfb/wfW8fWJA==", + "dev": true, + "engines": { + "node": ">= 10" + } + }, + "node_modules/is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-core-module": { + "version": "2.14.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.14.0.tgz", + "integrity": "sha512-a5dFJih5ZLYlRtDc0dZWP7RiKr6xIKzmn/oAYCDvdLThadVgyJwlaoQPmRtMSpz+rk0OGAgIu+TcM9HUF0fk1A==", + "dev": true, + "dependencies": { + "hasown": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-docker": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-3.0.0.tgz", + "integrity": "sha512-eljcgEDlEns/7AXFosB5K/2nCM4P7FQPkGc/DWLy5rmFEWvZayGrik1d9/QIY5nJ4f9YsVvBkA6kJpHn9rISdQ==", + "dev": true, + "bin": { + "is-docker": "cli.js" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", + "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-inside-container": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-inside-container/-/is-inside-container-1.0.0.tgz", + "integrity": "sha512-KIYLCCJghfHZxqjYBE7rEy0OBuTd5xCHS7tHVgvCLkx7StIoaxwNW3hCALgEUjFfeRk+MG/Qxmp/vtETEF3tRA==", + "dev": true, + "dependencies": { + "is-docker": "^3.0.0" + }, + "bin": { + "is-inside-container": "cli.js" + }, + "engines": { + "node": ">=14.16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-interactive": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-1.0.0.tgz", + "integrity": "sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-lambda": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-lambda/-/is-lambda-1.0.1.tgz", + "integrity": "sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ==", + "dev": true + }, + "node_modules/is-network-error": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-network-error/-/is-network-error-1.1.0.tgz", + "integrity": "sha512-tUdRRAnhT+OtCZR/LxZelH/C7QtjtFrTu5tXCA8pl55eTUElUHT+GPYV8MBMBvea/j+NxQqVt3LbWMRir7Gx9g==", + "dev": true, + "engines": { + "node": ">=16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/is-plain-obj": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-3.0.0.tgz", + "integrity": "sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, + "dependencies": { + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-stream": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", + "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-unicode-supported": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", + "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-what": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/is-what/-/is-what-3.14.1.tgz", + "integrity": "sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA==", + "dev": true + }, + "node_modules/is-wsl": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-3.1.0.tgz", + "integrity": "sha512-UcVfVfaK4Sc4m7X3dUSoHoozQGBEFeDC+zVo06t98xe8CzHSZZBekNXH+tu0NalHolcJ/QAGqS46Hef7QXBIMw==", + "dev": true, + "dependencies": { + "is-inside-container": "^1.0.0" + }, + "engines": { + "node": ">=16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", + "dev": true + }, + "node_modules/isbinaryfile": { + "version": "4.0.10", + "resolved": "https://registry.npmjs.org/isbinaryfile/-/isbinaryfile-4.0.10.tgz", + "integrity": "sha512-iHrqe5shvBUcFbmZq9zOQHBoeOhZJu6RQGrDpBgenUm/Am+F3JM2MgQj+rK3Z601fzrL5gLZWtAPH2OBaSVcyw==", + "dev": true, + "engines": { + "node": ">= 8.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/gjtorikian/" + } + }, + "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/isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/istanbul-lib-coverage": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", + "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-instrument": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.2.tgz", + "integrity": "sha512-1WUsZ9R1lA0HtBSohTkm39WTPlNKSJ5iFk7UwqXkBLoHQT+hfqPsfsTDVuZdKGaBwn7din9bS7SsnoAr943hvw==", + "dev": true, + "dependencies": { + "@babel/core": "^7.23.9", + "@babel/parser": "^7.23.9", + "@istanbuljs/schema": "^0.1.3", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^7.5.4" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-lib-report": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", + "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", + "dev": true, + "dependencies": { + "istanbul-lib-coverage": "^3.0.0", + "make-dir": "^4.0.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-lib-report/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-report/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-source-maps": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", + "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", + "dev": true, + "dependencies": { + "debug": "^4.1.1", + "istanbul-lib-coverage": "^3.0.0", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-lib-source-maps/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/istanbul-reports": { + "version": "3.1.7", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", + "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", + "dev": true, + "dependencies": { + "html-escaper": "^2.0.0", + "istanbul-lib-report": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/jackspeak": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz", + "integrity": "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==", + "dev": true, + "dependencies": { + "@isaacs/cliui": "^8.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + }, + "optionalDependencies": { + "@pkgjs/parseargs": "^0.11.0" + } + }, + "node_modules/jasmine-core": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-5.1.2.tgz", + "integrity": "sha512-2oIUMGn00FdUiqz6epiiJr7xcFyNYj3rDcfmnzfkBnHyBQ3cBQUs4mmyGsOb7TTLb9kxk7dBcmEmqhDKkBoDyA==", + "dev": true + }, + "node_modules/jest-worker": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", + "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", + "dev": true, + "dependencies": { + "@types/node": "*", + "merge-stream": "^2.0.0", + "supports-color": "^8.0.0" + }, + "engines": { + "node": ">= 10.13.0" + } + }, + "node_modules/jest-worker/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/jest-worker/node_modules/supports-color": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", + "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/supports-color?sponsor=1" + } + }, + "node_modules/jiti": { + "version": "1.21.6", + "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.6.tgz", + "integrity": "sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==", + "dev": true, + "bin": { + "jiti": "bin/jiti.js" + } + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsbn": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz", + "integrity": "sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A==", + "dev": true + }, + "node_modules/jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/json-parse-even-better-errors": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-3.0.2.tgz", + "integrity": "sha512-fi0NG4bPjCHunUJffmLd0gxssIgkNmArMvis4iNah6Owg1MCJjWhEcDLmsK6iGkJq3tHwbDkTlce70/tmXN4cQ==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "dev": true + }, + "node_modules/json5": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", + "dev": true, + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/jsonc-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.3.1.tgz", + "integrity": "sha512-HUgH65KyejrUFPvHFPbqOY0rsFip3Bo5wb4ngvdi1EpCYWUQDC5V+Y7mZws+DLkr4M//zQJoanu1SP+87Dv1oQ==", + "dev": true + }, + "node_modules/jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", + "dev": true, + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/jsonparse": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz", + "integrity": "sha512-POQXvpdL69+CluYsillJ7SUhKvytYjW9vG/GKpnf+xP8UWgYEM/RaMzHHofbALDiKbbP1W8UEYmgGl39WkPZsg==", + "dev": true, + "engines": [ + "node >= 0.2.0" + ] + }, + "node_modules/karma": { + "version": "6.4.3", + "resolved": "https://registry.npmjs.org/karma/-/karma-6.4.3.tgz", + "integrity": "sha512-LuucC/RE92tJ8mlCwqEoRWXP38UMAqpnq98vktmS9SznSoUPPUJQbc91dHcxcunROvfQjdORVA/YFviH+Xci9Q==", + "dev": true, + "dependencies": { + "@colors/colors": "1.5.0", + "body-parser": "^1.19.0", + "braces": "^3.0.2", + "chokidar": "^3.5.1", + "connect": "^3.7.0", + "di": "^0.0.1", + "dom-serialize": "^2.2.1", + "glob": "^7.1.7", + "graceful-fs": "^4.2.6", + "http-proxy": "^1.18.1", + "isbinaryfile": "^4.0.8", + "lodash": "^4.17.21", + "log4js": "^6.4.1", + "mime": "^2.5.2", + "minimatch": "^3.0.4", + "mkdirp": "^0.5.5", + "qjobs": "^1.2.0", + "range-parser": "^1.2.1", + "rimraf": "^3.0.2", + "socket.io": "^4.7.2", + "source-map": "^0.6.1", + "tmp": "^0.2.1", + "ua-parser-js": "^0.7.30", + "yargs": "^16.1.1" + }, + "bin": { + "karma": "bin/karma" + }, + "engines": { + "node": ">= 10" + } + }, + "node_modules/karma-chrome-launcher": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/karma-chrome-launcher/-/karma-chrome-launcher-3.2.0.tgz", + "integrity": "sha512-rE9RkUPI7I9mAxByQWkGJFXfFD6lE4gC5nPuZdobf/QdTEJI6EU4yIay/cfU/xV4ZxlM5JiTv7zWYgA64NpS5Q==", + "dev": true, + "dependencies": { + "which": "^1.2.1" + } + }, + "node_modules/karma-coverage": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/karma-coverage/-/karma-coverage-2.2.1.tgz", + "integrity": "sha512-yj7hbequkQP2qOSb20GuNSIyE//PgJWHwC2IydLE6XRtsnaflv+/OSGNssPjobYUlhVVagy99TQpqUt3vAUG7A==", + "dev": true, + "dependencies": { + "istanbul-lib-coverage": "^3.2.0", + "istanbul-lib-instrument": "^5.1.0", + "istanbul-lib-report": "^3.0.0", + "istanbul-lib-source-maps": "^4.0.1", + "istanbul-reports": "^3.0.5", + "minimatch": "^3.0.4" + }, + "engines": { + "node": ">=10.0.0" + } + }, + "node_modules/karma-coverage/node_modules/istanbul-lib-instrument": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", + "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", + "dev": true, + "dependencies": { + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/karma-coverage/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/karma-jasmine": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/karma-jasmine/-/karma-jasmine-5.1.0.tgz", + "integrity": "sha512-i/zQLFrfEpRyQoJF9fsCdTMOF5c2dK7C7OmsuKg2D0YSsuZSfQDiLuaiktbuio6F2wiCsZSnSnieIQ0ant/uzQ==", + "dev": true, + "dependencies": { + "jasmine-core": "^4.1.0" + }, + "engines": { + "node": ">=12" + }, + "peerDependencies": { + "karma": "^6.0.0" + } + }, + "node_modules/karma-jasmine-html-reporter": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/karma-jasmine-html-reporter/-/karma-jasmine-html-reporter-2.1.0.tgz", + "integrity": "sha512-sPQE1+nlsn6Hwb5t+HHwyy0A1FNCVKuL1192b+XNauMYWThz2kweiBVW1DqloRpVvZIJkIoHVB7XRpK78n1xbQ==", + "dev": true, + "peerDependencies": { + "jasmine-core": "^4.0.0 || ^5.0.0", + "karma": "^6.0.0", + "karma-jasmine": "^5.0.0" + } + }, + "node_modules/karma-jasmine/node_modules/jasmine-core": { + "version": "4.6.1", + "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-4.6.1.tgz", + "integrity": "sha512-VYz/BjjmC3klLJlLwA4Kw8ytk0zDSmbbDLNs794VnWmkcCB7I9aAL/D48VNQtmITyPvea2C3jdUMfc3kAoy0PQ==", + "dev": true + }, + "node_modules/karma-source-map-support": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/karma-source-map-support/-/karma-source-map-support-1.4.0.tgz", + "integrity": "sha512-RsBECncGO17KAoJCYXjv+ckIz+Ii9NCi+9enk+rq6XC81ezYkb4/RHE6CTXdA7IOJqoF3wcaLfVG0CPmE5ca6A==", + "dev": true, + "dependencies": { + "source-map-support": "^0.5.5" + } + }, + "node_modules/karma/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/karma/node_modules/cliui": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", + "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", + "dev": true, + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^7.0.0" + } + }, + "node_modules/karma/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/karma/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/karma/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/karma/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/karma/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/karma/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/karma/node_modules/tmp": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.2.3.tgz", + "integrity": "sha512-nZD7m9iCPC5g0pYmcaxogYKggSfLsdxl8of3Q/oIbqCqLLIO9IAF0GWjX1z9NZRHPiXv8Wex4yDCaZsgEw0Y8w==", + "dev": true, + "engines": { + "node": ">=14.14" + } + }, + "node_modules/karma/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/karma/node_modules/yargs": { + "version": "16.2.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", + "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", + "dev": true, + "dependencies": { + "cliui": "^7.0.2", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.0", + "y18n": "^5.0.5", + "yargs-parser": "^20.2.2" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/karma/node_modules/yargs-parser": { + "version": "20.2.9", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", + "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/launch-editor": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/launch-editor/-/launch-editor-2.8.0.tgz", + "integrity": "sha512-vJranOAJrI/llyWGRQqiDM+adrw+k83fvmmx3+nV47g3+36xM15jE+zyZ6Ffel02+xSvuM0b2GDRosXZkbb6wA==", + "dev": true, + "dependencies": { + "picocolors": "^1.0.0", + "shell-quote": "^1.8.1" + } + }, + "node_modules/less": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/less/-/less-4.2.0.tgz", + "integrity": "sha512-P3b3HJDBtSzsXUl0im2L7gTO5Ubg8mEN6G8qoTS77iXxXX4Hvu4Qj540PZDvQ8V6DmX6iXo98k7Md0Cm1PrLaA==", + "dev": true, + "dependencies": { + "copy-anything": "^2.0.1", + "parse-node-version": "^1.0.1", + "tslib": "^2.3.0" + }, + "bin": { + "lessc": "bin/lessc" + }, + "engines": { + "node": ">=6" + }, + "optionalDependencies": { + "errno": "^0.1.1", + "graceful-fs": "^4.1.2", + "image-size": "~0.5.0", + "make-dir": "^2.1.0", + "mime": "^1.4.1", + "needle": "^3.1.0", + "source-map": "~0.6.0" + } + }, + "node_modules/less-loader": { + "version": "12.2.0", + "resolved": "https://registry.npmjs.org/less-loader/-/less-loader-12.2.0.tgz", + "integrity": "sha512-MYUxjSQSBUQmowc0l5nPieOYwMzGPUaTzB6inNW/bdPEG9zOL3eAAD1Qw5ZxSPk7we5dMojHwNODYMV1hq4EVg==", + "dev": true, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "@rspack/core": "0.x || 1.x", + "less": "^3.5.0 || ^4.0.0", + "webpack": "^5.0.0" + }, + "peerDependenciesMeta": { + "@rspack/core": { + "optional": true + }, + "webpack": { + "optional": true + } + } + }, + "node_modules/less/node_modules/make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "optional": true, + "dependencies": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/less/node_modules/mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "dev": true, + "optional": true, + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/less/node_modules/semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true, + "optional": true, + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/less/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/license-webpack-plugin": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/license-webpack-plugin/-/license-webpack-plugin-4.0.2.tgz", + "integrity": "sha512-771TFWFD70G1wLTC4oU2Cw4qvtmNrIw+wRvBtn+okgHl7slJVi7zfNcdmqDL72BojM30VNJ2UHylr1o77U37Jw==", + "dev": true, + "dependencies": { + "webpack-sources": "^3.0.0" + }, + "peerDependenciesMeta": { + "webpack": { + "optional": true + }, + "webpack-sources": { + "optional": true + } + } + }, + "node_modules/lines-and-columns": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", + "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", + "dev": true + }, + "node_modules/listr2": { + "version": "8.2.3", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-8.2.3.tgz", + "integrity": "sha512-Lllokma2mtoniUOS94CcOErHWAug5iu7HOmDrvWgpw8jyQH2fomgB+7lZS4HWZxytUuQwkGOwe49FvwVaA85Xw==", + "dev": true, + "dependencies": { + "cli-truncate": "^4.0.0", + "colorette": "^2.0.20", + "eventemitter3": "^5.0.1", + "log-update": "^6.0.0", + "rfdc": "^1.4.1", + "wrap-ansi": "^9.0.0" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/listr2/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/listr2/node_modules/ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/listr2/node_modules/eventemitter3": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-5.0.1.tgz", + "integrity": "sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==", + "dev": true + }, + "node_modules/listr2/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "dev": true, + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/listr2/node_modules/wrap-ansi": { + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", + "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^6.2.1", + "string-width": "^7.0.0", + "strip-ansi": "^7.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/lmdb": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/lmdb/-/lmdb-3.0.12.tgz", + "integrity": "sha512-JnoEulTgveoC64vlYJ9sufGLuNkk6TcxSYpKxSC9aM42I61jIv3pQH0fgb6qW7HV0+FNqA3g1WCQQYfhfawGoQ==", + "dev": true, + "hasInstallScript": true, + "dependencies": { + "msgpackr": "^1.10.2", + "node-addon-api": "^6.1.0", + "node-gyp-build-optional-packages": "5.2.2", + "ordered-binary": "^1.4.1", + "weak-lru-cache": "^1.2.2" + }, + "bin": { + "download-lmdb-prebuilds": "bin/download-prebuilds.js" + }, + "optionalDependencies": { + "@lmdb/lmdb-darwin-arm64": "3.0.12", + "@lmdb/lmdb-darwin-x64": "3.0.12", + "@lmdb/lmdb-linux-arm": "3.0.12", + "@lmdb/lmdb-linux-arm64": "3.0.12", + "@lmdb/lmdb-linux-x64": "3.0.12", + "@lmdb/lmdb-win32-x64": "3.0.12" + } + }, + "node_modules/loader-runner": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz", + "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==", + "dev": true, + "engines": { + "node": ">=6.11.5" + } + }, + "node_modules/loader-utils": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.3.1.tgz", + "integrity": "sha512-FMJTLMXfCLMLfJxcX9PFqX5qD88Z5MRGaZCVzfuqeZSPsyiBzs+pahDQjbIWz2QIzPZz0NX9Zy4FX3lmK6YHIg==", + "dev": true, + "engines": { + "node": ">= 12.13.0" + } + }, + "node_modules/locate-path": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-7.2.0.tgz", + "integrity": "sha512-gvVijfZvn7R+2qyPX8mAuKcFGDf6Nc61GdvGafQsHL0sBIxfKzA+usWn4GFC/bk+QdwPUD4kWFJLhElipq+0VA==", + "dev": true, + "dependencies": { + "p-locate": "^6.0.0" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "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.debounce": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", + "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", + "dev": true + }, + "node_modules/log-symbols": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", + "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", + "dev": true, + "dependencies": { + "chalk": "^4.1.0", + "is-unicode-supported": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/log-symbols/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/log-symbols/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/log-symbols/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/log-symbols/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/log-symbols/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/log-symbols/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/log-update": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/log-update/-/log-update-6.0.0.tgz", + "integrity": "sha512-niTvB4gqvtof056rRIrTZvjNYE4rCUzO6X/X+kYjd7WFxXeJ0NwEFnRxX6ehkvv3jTwrXnNdtAak5XYZuIyPFw==", + "dev": true, + "dependencies": { + "ansi-escapes": "^6.2.0", + "cli-cursor": "^4.0.0", + "slice-ansi": "^7.0.0", + "strip-ansi": "^7.1.0", + "wrap-ansi": "^9.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/log-update/node_modules/ansi-escapes": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-6.2.1.tgz", + "integrity": "sha512-4nJ3yixlEthEJ9Rk4vPcdBRkZvQZlYyu8j4/Mqz5sgIkddmEnH2Yj2ZrnP9S3tQOvSNRUIgVNF/1yPpRAGNRig==", + "dev": true, + "engines": { + "node": ">=14.16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/log-update/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/log-update/node_modules/ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/log-update/node_modules/is-fullwidth-code-point": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.0.0.tgz", + "integrity": "sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA==", + "dev": true, + "dependencies": { + "get-east-asian-width": "^1.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/log-update/node_modules/slice-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.0.tgz", + "integrity": "sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==", + "dev": true, + "dependencies": { + "ansi-styles": "^6.2.1", + "is-fullwidth-code-point": "^5.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/chalk/slice-ansi?sponsor=1" + } + }, + "node_modules/log-update/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "dev": true, + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/log-update/node_modules/wrap-ansi": { + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", + "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^6.2.1", + "string-width": "^7.0.0", + "strip-ansi": "^7.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/log4js": { + "version": "6.9.1", + "resolved": "https://registry.npmjs.org/log4js/-/log4js-6.9.1.tgz", + "integrity": "sha512-1somDdy9sChrr9/f4UlzhdaGfDR2c/SaD2a4T7qEkG4jTS57/B3qmnjLYePwQ8cqWnUHZI0iAKxMBpCZICiZ2g==", + "dev": true, + "dependencies": { + "date-format": "^4.0.14", + "debug": "^4.3.4", + "flatted": "^3.2.7", + "rfdc": "^1.3.0", + "streamroller": "^3.1.5" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "dependencies": { + "yallist": "^3.0.2" + } + }, + "node_modules/magic-string": { + "version": "0.30.10", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.10.tgz", + "integrity": "sha512-iIRwTIf0QKV3UAnYK4PU8uiEc4SRh5jX0mwpIwETPpHdhVM4f53RSwS/vXvN1JhGX+Cs7B8qIq3d6AH49O5fAQ==", + "dev": true, + "dependencies": { + "@jridgewell/sourcemap-codec": "^1.4.15" + } + }, + "node_modules/make-dir": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", + "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", + "dev": true, + "dependencies": { + "semver": "^7.5.3" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/make-fetch-happen": { + "version": "13.0.1", + "resolved": "https://registry.npmjs.org/make-fetch-happen/-/make-fetch-happen-13.0.1.tgz", + "integrity": "sha512-cKTUFc/rbKUd/9meOvgrpJ2WrNzymt6jfRDdwg5UCnVzv9dTpEj9JS5m3wtziXVCjluIXyL8pcaukYqezIzZQA==", + "dev": true, + "dependencies": { + "@npmcli/agent": "^2.0.0", + "cacache": "^18.0.0", + "http-cache-semantics": "^4.1.1", + "is-lambda": "^1.0.1", + "minipass": "^7.0.2", + "minipass-fetch": "^3.0.0", + "minipass-flush": "^1.0.5", + "minipass-pipeline": "^1.2.4", + "negotiator": "^0.6.3", + "proc-log": "^4.2.0", + "promise-retry": "^2.0.1", + "ssri": "^10.0.0" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/memfs": { + "version": "4.9.3", + "resolved": "https://registry.npmjs.org/memfs/-/memfs-4.9.3.tgz", + "integrity": "sha512-bsYSSnirtYTWi1+OPMFb0M048evMKyUYe0EbtuGQgq6BVQM1g1W8/KIUJCCvjgI/El0j6Q4WsmMiBwLUBSw8LA==", + "dev": true, + "dependencies": { + "@jsonjoy.com/json-pack": "^1.0.3", + "@jsonjoy.com/util": "^1.1.2", + "tree-dump": "^1.0.1", + "tslib": "^2.0.0" + }, + "engines": { + "node": ">= 4.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/streamich" + } + }, + "node_modules/merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==", + "dev": true + }, + "node_modules/merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", + "dev": true + }, + "node_modules/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/methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/micromatch": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", + "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", + "dev": true, + "dependencies": { + "braces": "^3.0.3", + "picomatch": "^2.3.1" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/micromatch/node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/mime": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz", + "integrity": "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==", + "dev": true, + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "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==", + "dev": true, + "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==", + "dev": true, + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/mini-css-extract-plugin": { + "version": "2.9.0", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.9.0.tgz", + "integrity": "sha512-Zs1YsZVfemekSZG+44vBsYTLQORkPMwnlv+aehcxK/NLKC+EGhDB39/YePYYqx/sTk6NnYpuqikhSn7+JIevTA==", + "dev": true, + "dependencies": { + "schema-utils": "^4.0.0", + "tapable": "^2.2.1" + }, + "engines": { + "node": ">= 12.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^5.0.0" + } + }, + "node_modules/minimalistic-assert": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", + "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", + "dev": true + }, + "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/minimist": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", + "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "dev": true, + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, + "node_modules/minipass-collect": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/minipass-collect/-/minipass-collect-2.0.1.tgz", + "integrity": "sha512-D7V8PO9oaz7PWGLbCACuI1qEOsq7UKfLotx/C0Aet43fCUB/wfQ7DYeq2oR/svFJGYDHPr38SHATeaj/ZoKHKw==", + "dev": true, + "dependencies": { + "minipass": "^7.0.3" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, + "node_modules/minipass-fetch": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/minipass-fetch/-/minipass-fetch-3.0.5.tgz", + "integrity": "sha512-2N8elDQAtSnFV0Dk7gt15KHsS0Fyz6CbYZ360h0WTYV1Ty46li3rAXVOQj1THMNLdmrD9Vt5pBPtWtVkpwGBqg==", + "dev": true, + "dependencies": { + "minipass": "^7.0.3", + "minipass-sized": "^1.0.3", + "minizlib": "^2.1.2" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + }, + "optionalDependencies": { + "encoding": "^0.1.13" + } + }, + "node_modules/minipass-flush": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz", + "integrity": "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==", + "dev": true, + "dependencies": { + "minipass": "^3.0.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/minipass-flush/node_modules/minipass": { + "version": "3.3.6", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", + "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/minipass-flush/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, + "node_modules/minipass-pipeline": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz", + "integrity": "sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A==", + "dev": true, + "dependencies": { + "minipass": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/minipass-pipeline/node_modules/minipass": { + "version": "3.3.6", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", + "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/minipass-pipeline/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, + "node_modules/minipass-sized": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/minipass-sized/-/minipass-sized-1.0.3.tgz", + "integrity": "sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g==", + "dev": true, + "dependencies": { + "minipass": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/minipass-sized/node_modules/minipass": { + "version": "3.3.6", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", + "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/minipass-sized/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, + "node_modules/minizlib": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", + "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", + "dev": true, + "dependencies": { + "minipass": "^3.0.0", + "yallist": "^4.0.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/minizlib/node_modules/minipass": { + "version": "3.3.6", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", + "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/minizlib/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, + "node_modules/mkdirp": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", + "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", + "dev": true, + "dependencies": { + "minimist": "^1.2.6" + }, + "bin": { + "mkdirp": "bin/cmd.js" + } + }, + "node_modules/mrmime": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mrmime/-/mrmime-2.0.0.tgz", + "integrity": "sha512-eu38+hdgojoyq63s+yTpN4XMBdt5l8HhMhc4VKLO9KM5caLIBvUm4thi7fFaxyTmCKeNnXZ5pAlBwCUnhA09uw==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/msgpackr": { + "version": "1.10.2", + "resolved": "https://registry.npmjs.org/msgpackr/-/msgpackr-1.10.2.tgz", + "integrity": "sha512-L60rsPynBvNE+8BWipKKZ9jHcSGbtyJYIwjRq0VrIvQ08cRjntGXJYW/tmciZ2IHWIY8WEW32Qa2xbh5+SKBZA==", + "dev": true, + "optionalDependencies": { + "msgpackr-extract": "^3.0.2" + } + }, + "node_modules/msgpackr-extract": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/msgpackr-extract/-/msgpackr-extract-3.0.3.tgz", + "integrity": "sha512-P0efT1C9jIdVRefqjzOQ9Xml57zpOXnIuS+csaB4MdZbTdmGDLo8XhzBG1N7aO11gKDDkJvBLULeFTo46wwreA==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "dependencies": { + "node-gyp-build-optional-packages": "5.2.2" + }, + "bin": { + "download-msgpackr-prebuilds": "bin/download-prebuilds.js" + }, + "optionalDependencies": { + "@msgpackr-extract/msgpackr-extract-darwin-arm64": "3.0.3", + "@msgpackr-extract/msgpackr-extract-darwin-x64": "3.0.3", + "@msgpackr-extract/msgpackr-extract-linux-arm": "3.0.3", + "@msgpackr-extract/msgpackr-extract-linux-arm64": "3.0.3", + "@msgpackr-extract/msgpackr-extract-linux-x64": "3.0.3", + "@msgpackr-extract/msgpackr-extract-win32-x64": "3.0.3" + } + }, + "node_modules/multicast-dns": { + "version": "7.2.5", + "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-7.2.5.tgz", + "integrity": "sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg==", + "dev": true, + "dependencies": { + "dns-packet": "^5.2.2", + "thunky": "^1.0.2" + }, + "bin": { + "multicast-dns": "cli.js" + } + }, + "node_modules/mute-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-1.0.0.tgz", + "integrity": "sha512-avsJQhyd+680gKXyG/sQc0nXaC6rBkPOfyHYcFb9+hdkqQkR9bdnkJ0AMZhke0oesPqIO+mFFJ+IdBc7mst4IA==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/needle": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/needle/-/needle-3.3.1.tgz", + "integrity": "sha512-6k0YULvhpw+RoLNiQCRKOl09Rv1dPLr8hHnVjHqdolKwDrdNyk+Hmrthi4lIGPPz3r39dLx0hsF5s40sZ3Us4Q==", + "dev": true, + "optional": true, + "dependencies": { + "iconv-lite": "^0.6.3", + "sax": "^1.2.4" + }, + "bin": { + "needle": "bin/needle" + }, + "engines": { + "node": ">= 4.4.x" + } + }, + "node_modules/needle/node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "dev": true, + "optional": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/negotiator": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", + "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/neo-async": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", + "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==", + "dev": true + }, + "node_modules/nice-napi": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/nice-napi/-/nice-napi-1.0.2.tgz", + "integrity": "sha512-px/KnJAJZf5RuBGcfD+Sp2pAKq0ytz8j+1NehvgIGFkvtvFrDM3T8E4x/JJODXK9WZow8RRGrbA9QQ3hs+pDhA==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "!win32" + ], + "dependencies": { + "node-addon-api": "^3.0.0", + "node-gyp-build": "^4.2.2" + } + }, + "node_modules/nice-napi/node_modules/node-addon-api": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.1.tgz", + "integrity": "sha512-mmcei9JghVNDYydghQmeDX8KoAm0FAiYyIcUt/N4nhyAipB17pllZQDOJD2fotxABnt4Mdz+dKTO7eftLg4d0A==", + "dev": true, + "optional": true + }, + "node_modules/node-addon-api": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-6.1.0.tgz", + "integrity": "sha512-+eawOlIgy680F0kBzPUNFhMZGtJ1YmqM6l4+Crf4IkImjYrO/mqPwRMh352g23uIaQKFItcQ64I7KMaJxHgAVA==", + "dev": true + }, + "node_modules/node-forge": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", + "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", + "dev": true, + "engines": { + "node": ">= 6.13.0" + } + }, + "node_modules/node-gyp": { + "version": "10.2.0", + "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-10.2.0.tgz", + "integrity": "sha512-sp3FonBAaFe4aYTcFdZUn2NYkbP7xroPGYvQmP4Nl5PxamznItBnNCgjrVTKrEfQynInMsJvZrdmqUnysCJ8rw==", + "dev": true, + "dependencies": { + "env-paths": "^2.2.0", + "exponential-backoff": "^3.1.1", + "glob": "^10.3.10", + "graceful-fs": "^4.2.6", + "make-fetch-happen": "^13.0.0", + "nopt": "^7.0.0", + "proc-log": "^4.1.0", + "semver": "^7.3.5", + "tar": "^6.2.1", + "which": "^4.0.0" + }, + "bin": { + "node-gyp": "bin/node-gyp.js" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/node-gyp-build": { + "version": "4.8.1", + "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.8.1.tgz", + "integrity": "sha512-OSs33Z9yWr148JZcbZd5WiAXhh/n9z8TxQcdMhIOlpN9AhWpLfvVFO73+m77bBABQMaY9XSvIa+qk0jlI7Gcaw==", + "dev": true, + "optional": true, + "bin": { + "node-gyp-build": "bin.js", + "node-gyp-build-optional": "optional.js", + "node-gyp-build-test": "build-test.js" + } + }, + "node_modules/node-gyp-build-optional-packages": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/node-gyp-build-optional-packages/-/node-gyp-build-optional-packages-5.2.2.tgz", + "integrity": "sha512-s+w+rBWnpTMwSFbaE0UXsRlg7hU4FjekKU4eyAih5T8nJuNZT1nNsskXpxmeqSK9UzkBl6UgRlnKc8hz8IEqOw==", + "dev": true, + "dependencies": { + "detect-libc": "^2.0.1" + }, + "bin": { + "node-gyp-build-optional-packages": "bin.js", + "node-gyp-build-optional-packages-optional": "optional.js", + "node-gyp-build-optional-packages-test": "build-test.js" + } + }, + "node_modules/node-gyp/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/node-gyp/node_modules/glob": { + "version": "10.4.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", + "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", + "dev": true, + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^3.1.2", + "minimatch": "^9.0.4", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^1.11.1" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/node-gyp/node_modules/isexe": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-3.1.1.tgz", + "integrity": "sha512-LpB/54B+/2J5hqQ7imZHfdU31OlgQqx7ZicVlkm9kzg9/w8GKLEcFfJl/t7DCEDueOyBAD6zCCwTO6Fzs0NoEQ==", + "dev": true, + "engines": { + "node": ">=16" + } + }, + "node_modules/node-gyp/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/node-gyp/node_modules/which": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/which/-/which-4.0.0.tgz", + "integrity": "sha512-GlaYyEb07DPxYCKhKzplCWBJtvxZcZMrL+4UkrTSJHHPyZU4mYYTv3qaOe77H7EODLSSopAUFAc6W8U4yqvscg==", + "dev": true, + "dependencies": { + "isexe": "^3.1.1" + }, + "bin": { + "node-which": "bin/which.js" + }, + "engines": { + "node": "^16.13.0 || >=18.0.0" + } + }, + "node_modules/node-releases": { + "version": "2.0.14", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", + "dev": true + }, + "node_modules/nopt": { + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-7.2.1.tgz", + "integrity": "sha512-taM24ViiimT/XntxbPyJQzCG+p4EKOpgD3mxFwW38mGjVUrfERQOeY4EDHjdnptttfHuHQXFx+lTP08Q+mLa/w==", + "dev": true, + "dependencies": { + "abbrev": "^2.0.0" + }, + "bin": { + "nopt": "bin/nopt.js" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/normalize-package-data": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-6.0.2.tgz", + "integrity": "sha512-V6gygoYb/5EmNI+MEGrWkC+e6+Rr7mTmfHrxDbLzxQogBkgzo76rkok0Am6thgSF7Mv2nLOajAJj5vDJZEFn7g==", + "dev": true, + "dependencies": { + "hosted-git-info": "^7.0.0", + "semver": "^7.3.5", + "validate-npm-package-license": "^3.0.4" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", + "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/npm-bundled": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-3.0.1.tgz", + "integrity": "sha512-+AvaheE/ww1JEwRHOrn4WHNzOxGtVp+adrg2AeZS/7KuxGUYFuBta98wYpfHBbJp6Tg6j1NKSEVHNcfZzJHQwQ==", + "dev": true, + "dependencies": { + "npm-normalize-package-bin": "^3.0.0" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/npm-install-checks": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/npm-install-checks/-/npm-install-checks-6.3.0.tgz", + "integrity": "sha512-W29RiK/xtpCGqn6f3ixfRYGk+zRyr+Ew9F2E20BfXxT5/euLdA/Nm7fO7OeTGuAmTs30cpgInyJ0cYe708YTZw==", + "dev": true, + "dependencies": { + "semver": "^7.1.1" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/npm-normalize-package-bin": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-3.0.1.tgz", + "integrity": "sha512-dMxCf+zZ+3zeQZXKxmyuCKlIDPGuv8EF940xbkC4kQVDTtqoh6rJFO+JTKSA6/Rwi0getWmtuy4Itup0AMcaDQ==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/npm-package-arg": { + "version": "11.0.2", + "resolved": "https://registry.npmjs.org/npm-package-arg/-/npm-package-arg-11.0.2.tgz", + "integrity": "sha512-IGN0IAwmhDJwy13Wc8k+4PEbTPhpJnMtfR53ZbOyjkvmEcLS4nCwp6mvMWjS5sUjeiW3mpx6cHmuhKEu9XmcQw==", + "dev": true, + "dependencies": { + "hosted-git-info": "^7.0.0", + "proc-log": "^4.0.0", + "semver": "^7.3.5", + "validate-npm-package-name": "^5.0.0" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/npm-packlist": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-8.0.2.tgz", + "integrity": "sha512-shYrPFIS/JLP4oQmAwDyk5HcyysKW8/JLTEA32S0Z5TzvpaeeX2yMFfoK1fjEBnCBvVyIB/Jj/GBFdm0wsgzbA==", + "dev": true, + "dependencies": { + "ignore-walk": "^6.0.4" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/npm-pick-manifest": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/npm-pick-manifest/-/npm-pick-manifest-9.0.1.tgz", + "integrity": "sha512-Udm1f0l2nXb3wxDpKjfohwgdFUSV50UVwzEIpDXVsbDMXVIEF81a/i0UhuQbhrPMMmdiq3+YMFLFIRVLs3hxQw==", + "dev": true, + "dependencies": { + "npm-install-checks": "^6.0.0", + "npm-normalize-package-bin": "^3.0.0", + "npm-package-arg": "^11.0.0", + "semver": "^7.3.5" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/npm-registry-fetch": { + "version": "17.1.0", + "resolved": "https://registry.npmjs.org/npm-registry-fetch/-/npm-registry-fetch-17.1.0.tgz", + "integrity": "sha512-5+bKQRH0J1xG1uZ1zMNvxW0VEyoNWgJpY9UDuluPFLKDfJ9u2JmmjmTJV1srBGQOROfdBMiVvnH2Zvpbm+xkVA==", + "dev": true, + "dependencies": { + "@npmcli/redact": "^2.0.0", + "jsonparse": "^1.3.1", + "make-fetch-happen": "^13.0.0", + "minipass": "^7.0.2", + "minipass-fetch": "^3.0.0", + "minizlib": "^2.1.2", + "npm-package-arg": "^11.0.0", + "proc-log": "^4.0.0" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", + "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", + "dev": true, + "dependencies": { + "path-key": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/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/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", + "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/obuf": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz", + "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==", + "dev": true + }, + "node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dev": true, + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/on-headers": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", + "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", + "dev": true, + "dependencies": { + "mimic-fn": "^2.1.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/open": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/open/-/open-10.1.0.tgz", + "integrity": "sha512-mnkeQ1qP5Ue2wd+aivTD3NHd/lZ96Lu0jgf0pwktLPtx6cTZiH7tyeGRRHs0zX0rbrahXPnXlUnbeXyaBBuIaw==", + "dev": true, + "dependencies": { + "default-browser": "^5.2.1", + "define-lazy-prop": "^3.0.0", + "is-inside-container": "^1.0.0", + "is-wsl": "^3.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ora": { + "version": "5.4.1", + "resolved": "https://registry.npmjs.org/ora/-/ora-5.4.1.tgz", + "integrity": "sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ==", + "dev": true, + "dependencies": { + "bl": "^4.1.0", + "chalk": "^4.1.0", + "cli-cursor": "^3.1.0", + "cli-spinners": "^2.5.0", + "is-interactive": "^1.0.0", + "is-unicode-supported": "^0.1.0", + "log-symbols": "^4.1.0", + "strip-ansi": "^6.0.0", + "wcwidth": "^1.0.1" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ora/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/ora/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/ora/node_modules/cli-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", + "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", + "dev": true, + "dependencies": { + "restore-cursor": "^3.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/ora/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/ora/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/ora/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/ora/node_modules/restore-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", + "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", + "dev": true, + "dependencies": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/ora/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + }, + "node_modules/ora/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/ordered-binary": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/ordered-binary/-/ordered-binary-1.5.1.tgz", + "integrity": "sha512-5VyHfHY3cd0iza71JepYG50My+YUbrFtGoUz2ooEydPyPM7Aai/JW098juLr+RG6+rDJuzNNTsEQu2DZa1A41A==", + "dev": true + }, + "node_modules/os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/p-limit": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-4.0.0.tgz", + "integrity": "sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ==", + "dev": true, + "dependencies": { + "yocto-queue": "^1.0.0" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-6.0.0.tgz", + "integrity": "sha512-wPrq66Llhl7/4AGC6I+cqxT07LhXvWL08LNXz1fENOw0Ap4sRZZ/gZpTTJ5jpurzzzfS2W/Ge9BY3LgLjCShcw==", + "dev": true, + "dependencies": { + "p-limit": "^4.0.0" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-map": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", + "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", + "dev": true, + "dependencies": { + "aggregate-error": "^3.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-retry": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-6.2.0.tgz", + "integrity": "sha512-JA6nkq6hKyWLLasXQXUrO4z8BUZGUt/LjlJxx8Gb2+2ntodU/SS63YZ8b0LUTbQ8ZB9iwOfhEPhg4ykKnn2KsA==", + "dev": true, + "dependencies": { + "@types/retry": "0.12.2", + "is-network-error": "^1.0.0", + "retry": "^0.13.1" + }, + "engines": { + "node": ">=16.17" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-retry/node_modules/retry": { + "version": "0.13.1", + "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz", + "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/package-json-from-dist": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.0.tgz", + "integrity": "sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==", + "dev": true + }, + "node_modules/pacote": { + "version": "18.0.6", + "resolved": "https://registry.npmjs.org/pacote/-/pacote-18.0.6.tgz", + "integrity": "sha512-+eK3G27SMwsB8kLIuj4h1FUhHtwiEUo21Tw8wNjmvdlpOEr613edv+8FUsTj/4F/VN5ywGE19X18N7CC2EJk6A==", + "dev": true, + "dependencies": { + "@npmcli/git": "^5.0.0", + "@npmcli/installed-package-contents": "^2.0.1", + "@npmcli/package-json": "^5.1.0", + "@npmcli/promise-spawn": "^7.0.0", + "@npmcli/run-script": "^8.0.0", + "cacache": "^18.0.0", + "fs-minipass": "^3.0.0", + "minipass": "^7.0.2", + "npm-package-arg": "^11.0.0", + "npm-packlist": "^8.0.0", + "npm-pick-manifest": "^9.0.0", + "npm-registry-fetch": "^17.0.0", + "proc-log": "^4.0.0", + "promise-retry": "^2.0.1", + "sigstore": "^2.2.0", + "ssri": "^10.0.0", + "tar": "^6.1.11" + }, + "bin": { + "pacote": "bin/index.js" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/parse-json": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", + "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/parse-json/node_modules/json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true + }, + "node_modules/parse-node-version": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parse-node-version/-/parse-node-version-1.0.1.tgz", + "integrity": "sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==", + "dev": true, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/parse5": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.2.tgz", + "integrity": "sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==", + "dev": true, + "dependencies": { + "entities": "^4.4.0" + }, + "funding": { + "url": "https://github.com/inikulin/parse5?sponsor=1" + } + }, + "node_modules/parse5-html-rewriting-stream": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/parse5-html-rewriting-stream/-/parse5-html-rewriting-stream-7.0.0.tgz", + "integrity": "sha512-mazCyGWkmCRWDI15Zp+UiCqMp/0dgEmkZRvhlsqqKYr4SsVm/TvnSpD9fCvqCA2zoWJcfRym846ejWBBHRiYEg==", + "dev": true, + "dependencies": { + "entities": "^4.3.0", + "parse5": "^7.0.0", + "parse5-sax-parser": "^7.0.0" + }, + "funding": { + "url": "https://github.com/inikulin/parse5?sponsor=1" + } + }, + "node_modules/parse5-sax-parser": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/parse5-sax-parser/-/parse5-sax-parser-7.0.0.tgz", + "integrity": "sha512-5A+v2SNsq8T6/mG3ahcz8ZtQ0OUFTatxPbeidoMB7tkJSGDY3tdfl4MHovtLQHkEn5CGxijNWRQHhRQ6IRpXKg==", + "dev": true, + "dependencies": { + "parse5": "^7.0.0" + }, + "funding": { + "url": "https://github.com/inikulin/parse5?sponsor=1" + } + }, + "node_modules/parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/path-exists": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-5.0.0.tgz", + "integrity": "sha512-RjhtfwJOxzcFmNOi6ltcbcu4Iu+FL3zEj83dk4kAS+fVpTxXLO1b38RvJgT/0QwvV/L3aY9TAnyv0EOqW4GoMQ==", + "dev": true, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "node_modules/path-scurry": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", + "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", + "dev": true, + "dependencies": { + "lru-cache": "^10.2.0", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" + }, + "engines": { + "node": ">=16 || 14 >=14.18" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/path-scurry/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", + "dev": true + }, + "node_modules/path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", + "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==", + "dev": true + }, + "node_modules/path-type": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-5.0.0.tgz", + "integrity": "sha512-5HviZNaZcfqP95rwpv+1HDgUamezbqdSYTyzjTvwtJSnIH+3vnbmWsItli8OFEndS984VT55M3jduxZbX351gg==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/picocolors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", + "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", + "dev": true + }, + "node_modules/picomatch": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.2.tgz", + "integrity": "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true, + "optional": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/piscina": { + "version": "4.6.1", + "resolved": "https://registry.npmjs.org/piscina/-/piscina-4.6.1.tgz", + "integrity": "sha512-z30AwWGtQE+Apr+2WBZensP2lIvwoaMcOPkQlIEmSGMJNUvaYACylPYrQM6wSdUNJlnDVMSpLv7xTMJqlVshOA==", + "dev": true, + "optionalDependencies": { + "nice-napi": "^1.0.2" + } + }, + "node_modules/pkg-dir": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-7.0.0.tgz", + "integrity": "sha512-Ie9z/WINcxxLp27BKOCHGde4ITq9UklYKDzVo1nhk5sqGEXU3FpkwP5GM2voTGJkGd9B3Otl+Q4uwSOeSUtOBA==", + "dev": true, + "dependencies": { + "find-up": "^6.3.0" + }, + "engines": { + "node": ">=14.16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/postcss": { + "version": "8.4.38", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", + "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.0.0", + "source-map-js": "^1.2.0" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/postcss-loader": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-8.1.1.tgz", + "integrity": "sha512-0IeqyAsG6tYiDRCYKQJLAmgQr47DX6N7sFSWvQxt6AcupX8DIdmykuk/o/tx0Lze3ErGHJEp5OSRxrelC6+NdQ==", + "dev": true, + "dependencies": { + "cosmiconfig": "^9.0.0", + "jiti": "^1.20.0", + "semver": "^7.5.4" + }, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "@rspack/core": "0.x || 1.x", + "postcss": "^7.0.0 || ^8.0.1", + "webpack": "^5.0.0" + }, + "peerDependenciesMeta": { + "@rspack/core": { + "optional": true + }, + "webpack": { + "optional": true + } + } + }, + "node_modules/postcss-media-query-parser": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/postcss-media-query-parser/-/postcss-media-query-parser-0.2.3.tgz", + "integrity": "sha512-3sOlxmbKcSHMjlUXQZKQ06jOswE7oVkXPxmZdoB1r5l0q6gTFTQSHxNxOrCccElbW7dxNytifNEo8qidX2Vsig==", + "dev": true + }, + "node_modules/postcss-modules-extract-imports": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.1.0.tgz", + "integrity": "sha512-k3kNe0aNFQDAZGbin48pL2VNidTF0w4/eASDsxlyspobzU3wZQLOGj7L9gfRe0Jo9/4uud09DsjFNH7winGv8Q==", + "dev": true, + "engines": { + "node": "^10 || ^12 || >= 14" + }, + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/postcss-modules-local-by-default": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.5.tgz", + "integrity": "sha512-6MieY7sIfTK0hYfafw1OMEG+2bg8Q1ocHCpoWLqOKj3JXlKu4G7btkmM/B7lFubYkYWmRSPLZi5chid63ZaZYw==", + "dev": true, + "dependencies": { + "icss-utils": "^5.0.0", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.1.0" + }, + "engines": { + "node": "^10 || ^12 || >= 14" + }, + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/postcss-modules-scope": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.2.0.tgz", + "integrity": "sha512-oq+g1ssrsZOsx9M96c5w8laRmvEu9C3adDSjI8oTcbfkrTE8hx/zfyobUoWIxaKPO8bt6S62kxpw5GqypEw1QQ==", + "dev": true, + "dependencies": { + "postcss-selector-parser": "^6.0.4" + }, + "engines": { + "node": "^10 || ^12 || >= 14" + }, + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/postcss-modules-values": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz", + "integrity": "sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ==", + "dev": true, + "dependencies": { + "icss-utils": "^5.0.0" + }, + "engines": { + "node": "^10 || ^12 || >= 14" + }, + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/postcss-selector-parser": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.1.1.tgz", + "integrity": "sha512-b4dlw/9V8A71rLIDsSwVmak9z2DuBUB7CA1/wSdelNEzqsjoSPeADTWNO09lpH49Diy3/JIZ2bSPB1dI3LJCHg==", + "dev": true, + "dependencies": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/postcss-value-parser": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", + "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", + "dev": true + }, + "node_modules/proc-log": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/proc-log/-/proc-log-4.2.0.tgz", + "integrity": "sha512-g8+OnU/L2v+wyiVK+D5fA34J7EH8jZ8DDlvwhRCMxmMj7UCBvxiO1mGeN+36JXIKF4zevU4kRBd8lVgG9vLelA==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", + "dev": true + }, + "node_modules/promise-inflight": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", + "integrity": "sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g==", + "dev": true + }, + "node_modules/promise-retry": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/promise-retry/-/promise-retry-2.0.1.tgz", + "integrity": "sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g==", + "dev": true, + "dependencies": { + "err-code": "^2.0.2", + "retry": "^0.12.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "dev": true, + "dependencies": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/proxy-addr/node_modules/ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "dev": true, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/prr": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", + "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==", + "dev": true, + "optional": true + }, + "node_modules/punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ==", + "dev": true + }, + "node_modules/qjobs": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/qjobs/-/qjobs-1.2.0.tgz", + "integrity": "sha512-8YOJEHtxpySA3fFDyCRxA+UUV+fA+rTWnuWvylOK/NCjhY+b4ocCtmu8TtsWb+mYeU+GCHf/S66KZF/AsteKHg==", + "dev": true, + "engines": { + "node": ">=0.9" + } + }, + "node_modules/qs": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", + "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", + "dev": true, + "dependencies": { + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "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/randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", + "dev": true, + "dependencies": { + "safe-buffer": "^5.1.0" + } + }, + "node_modules/range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/raw-body": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", + "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", + "dev": true, + "dependencies": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/readdirp/node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/reflect-metadata": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.2.2.tgz", + "integrity": "sha512-urBwgfrvVP/eAyXx4hluJivBKzuEbSQs9rKWCrCkbSxNv8mxPcUZKeuoF3Uy4mJl3Lwprp6yy5/39VWigZ4K6Q==", + "dev": true + }, + "node_modules/regenerate": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", + "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", + "dev": true + }, + "node_modules/regenerate-unicode-properties": { + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.1.tgz", + "integrity": "sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==", + "dev": true, + "dependencies": { + "regenerate": "^1.4.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/regenerator-runtime": { + "version": "0.14.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz", + "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==", + "dev": true + }, + "node_modules/regenerator-transform": { + "version": "0.15.2", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.2.tgz", + "integrity": "sha512-hfMp2BoF0qOk3uc5V20ALGDS2ddjQaLrdl7xrGXvAIow7qeWRM2VA2HuCHkUKk9slq3VwEwLNK3DFBqDfPGYtg==", + "dev": true, + "dependencies": { + "@babel/runtime": "^7.8.4" + } + }, + "node_modules/regex-parser": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/regex-parser/-/regex-parser-2.3.0.tgz", + "integrity": "sha512-TVILVSz2jY5D47F4mA4MppkBrafEaiUWJO/TcZHEIuI13AqoZMkK1WMA4Om1YkYbTx+9Ki1/tSUXbceyr9saRg==", + "dev": true + }, + "node_modules/regexpu-core": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.3.2.tgz", + "integrity": "sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ==", + "dev": true, + "dependencies": { + "@babel/regjsgen": "^0.8.0", + "regenerate": "^1.4.2", + "regenerate-unicode-properties": "^10.1.0", + "regjsparser": "^0.9.1", + "unicode-match-property-ecmascript": "^2.0.0", + "unicode-match-property-value-ecmascript": "^2.1.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/regjsparser": { + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz", + "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==", + "dev": true, + "dependencies": { + "jsesc": "~0.5.0" + }, + "bin": { + "regjsparser": "bin/parser" + } + }, + "node_modules/regjsparser/node_modules/jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", + "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", + "dev": true + }, + "node_modules/resolve": { + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", + "dev": true, + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/resolve-url-loader": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-url-loader/-/resolve-url-loader-5.0.0.tgz", + "integrity": "sha512-uZtduh8/8srhBoMx//5bwqjQ+rfYOUq8zC9NrMUGtjBiGTtFJM42s58/36+hTqeqINcnYe08Nj3LkK9lW4N8Xg==", + "dev": true, + "dependencies": { + "adjust-sourcemap-loader": "^4.0.0", + "convert-source-map": "^1.7.0", + "loader-utils": "^2.0.0", + "postcss": "^8.2.14", + "source-map": "0.6.1" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/resolve-url-loader/node_modules/loader-utils": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz", + "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==", + "dev": true, + "dependencies": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^2.1.2" + }, + "engines": { + "node": ">=8.9.0" + } + }, + "node_modules/resolve-url-loader/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/restore-cursor": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-4.0.0.tgz", + "integrity": "sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg==", + "dev": true, + "dependencies": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/restore-cursor/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + }, + "node_modules/retry": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", + "integrity": "sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==", + "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/rfdc": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.4.1.tgz", + "integrity": "sha512-q1b3N5QkRUWUl7iyylaaj3kOpIT0N2i9MqIEQXP73GVsN9cw3fdx8X63cEmWhJGi2PPCF23Ijp7ktmd39rawIA==", + "dev": true + }, + "node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dev": true, + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rollup": { + "version": "4.18.0", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.18.0.tgz", + "integrity": "sha512-QmJz14PX3rzbJCN1SG4Xe/bAAX2a6NpCP8ab2vfu2GiUr8AQcr2nCV/oEO3yneFarB67zk8ShlIyWb2LGTb3Sg==", + "dev": true, + "dependencies": { + "@types/estree": "1.0.5" + }, + "bin": { + "rollup": "dist/bin/rollup" + }, + "engines": { + "node": ">=18.0.0", + "npm": ">=8.0.0" + }, + "optionalDependencies": { + "@rollup/rollup-android-arm-eabi": "4.18.0", + "@rollup/rollup-android-arm64": "4.18.0", + "@rollup/rollup-darwin-arm64": "4.18.0", + "@rollup/rollup-darwin-x64": "4.18.0", + "@rollup/rollup-linux-arm-gnueabihf": "4.18.0", + "@rollup/rollup-linux-arm-musleabihf": "4.18.0", + "@rollup/rollup-linux-arm64-gnu": "4.18.0", + "@rollup/rollup-linux-arm64-musl": "4.18.0", + "@rollup/rollup-linux-powerpc64le-gnu": "4.18.0", + "@rollup/rollup-linux-riscv64-gnu": "4.18.0", + "@rollup/rollup-linux-s390x-gnu": "4.18.0", + "@rollup/rollup-linux-x64-gnu": "4.18.0", + "@rollup/rollup-linux-x64-musl": "4.18.0", + "@rollup/rollup-win32-arm64-msvc": "4.18.0", + "@rollup/rollup-win32-ia32-msvc": "4.18.0", + "@rollup/rollup-win32-x64-msvc": "4.18.0", + "fsevents": "~2.3.2" + } + }, + "node_modules/run-applescript": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/run-applescript/-/run-applescript-7.0.0.tgz", + "integrity": "sha512-9by4Ij99JUr/MCFBUkDKLWK3G9HVXmabKz9U5MlIAIuvuzkiOicRYs8XJLxX+xahD+mLiiCYDqF9dKAgtzKP1A==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "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/rxjs": { + "version": "7.8.1", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.1.tgz", + "integrity": "sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==", + "dependencies": { + "tslib": "^2.1.0" + } + }, + "node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "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/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "node_modules/sass": { + "version": "1.77.6", + "resolved": "https://registry.npmjs.org/sass/-/sass-1.77.6.tgz", + "integrity": "sha512-ByXE1oLD79GVq9Ht1PeHWCPMPB8XHpBuz1r85oByKHjZY6qV6rWnQovQzXJXuQ/XyE1Oj3iPk3lo28uzaRA2/Q==", + "dev": 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/sass-loader": { + "version": "14.2.1", + "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-14.2.1.tgz", + "integrity": "sha512-G0VcnMYU18a4N7VoNDegg2OuMjYtxnqzQWARVWCIVSZwJeiL9kg8QMsuIZOplsJgTzZLF6jGxI3AClj8I9nRdQ==", + "dev": true, + "dependencies": { + "neo-async": "^2.6.2" + }, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "@rspack/core": "0.x || 1.x", + "node-sass": "^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0 || ^9.0.0", + "sass": "^1.3.0", + "sass-embedded": "*", + "webpack": "^5.0.0" + }, + "peerDependenciesMeta": { + "@rspack/core": { + "optional": true + }, + "node-sass": { + "optional": true + }, + "sass": { + "optional": true + }, + "sass-embedded": { + "optional": true + }, + "webpack": { + "optional": true + } + } + }, + "node_modules/sax": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.4.1.tgz", + "integrity": "sha512-+aWOz7yVScEGoKNd4PA10LZ8sk0A/z5+nXQG5giUO5rprX9jgYsTdov9qCchZiPIZezbZH+jRut8nPodFAX4Jg==", + "dev": true, + "optional": true + }, + "node_modules/schema-utils": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz", + "integrity": "sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw==", + "dev": true, + "dependencies": { + "@types/json-schema": "^7.0.9", + "ajv": "^8.9.0", + "ajv-formats": "^2.1.1", + "ajv-keywords": "^5.1.0" + }, + "engines": { + "node": ">= 12.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + } + }, + "node_modules/schema-utils/node_modules/ajv-formats": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz", + "integrity": "sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==", + "dev": true, + "dependencies": { + "ajv": "^8.0.0" + }, + "peerDependencies": { + "ajv": "^8.0.0" + }, + "peerDependenciesMeta": { + "ajv": { + "optional": true + } + } + }, + "node_modules/select-hose": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", + "integrity": "sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg==", + "dev": true + }, + "node_modules/selfsigned": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.4.1.tgz", + "integrity": "sha512-th5B4L2U+eGLq1TVh7zNRGBapioSORUeymIydxgFpwww9d2qyKvtuPU2jJuHvYAwwqi2Y596QBL3eEqcPEYL8Q==", + "dev": true, + "dependencies": { + "@types/node-forge": "^1.3.0", + "node-forge": "^1" + }, + "engines": { + "node": ">=10" + } + }, + "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/send": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", + "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", + "dev": true, + "dependencies": { + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "mime": "1.6.0", + "ms": "2.1.3", + "on-finished": "2.4.1", + "range-parser": "~1.2.1", + "statuses": "2.0.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/send/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/send/node_modules/debug/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/send/node_modules/mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "dev": true, + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/send/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true + }, + "node_modules/send/node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/serialize-javascript": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.2.tgz", + "integrity": "sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==", + "dev": true, + "dependencies": { + "randombytes": "^2.1.0" + } + }, + "node_modules/serve-index": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz", + "integrity": "sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw==", + "dev": true, + "dependencies": { + "accepts": "~1.3.4", + "batch": "0.6.1", + "debug": "2.6.9", + "escape-html": "~1.0.3", + "http-errors": "~1.6.2", + "mime-types": "~2.1.17", + "parseurl": "~1.3.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/serve-index/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/serve-index/node_modules/depd": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", + "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/serve-index/node_modules/http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", + "integrity": "sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A==", + "dev": true, + "dependencies": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/serve-index/node_modules/inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==", + "dev": true + }, + "node_modules/serve-index/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/serve-index/node_modules/setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", + "dev": true + }, + "node_modules/serve-static": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", + "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", + "dev": true, + "dependencies": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.18.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "dev": true, + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", + "dev": true + }, + "node_modules/shallow-clone": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", + "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", + "dev": true, + "dependencies": { + "kind-of": "^6.0.2" + }, + "engines": { + "node": ">=8" + } + }, + "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/shell-quote": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", + "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/signal-exit": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", + "dev": true, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/sigstore": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/sigstore/-/sigstore-2.3.1.tgz", + "integrity": "sha512-8G+/XDU8wNsJOQS5ysDVO0Etg9/2uA5gR9l4ZwijjlwxBcrU6RPfwi2+jJmbP+Ap1Hlp/nVAaEO4Fj22/SL2gQ==", + "dev": true, + "dependencies": { + "@sigstore/bundle": "^2.3.2", + "@sigstore/core": "^1.0.0", + "@sigstore/protobuf-specs": "^0.3.2", + "@sigstore/sign": "^2.3.2", + "@sigstore/tuf": "^2.3.4", + "@sigstore/verify": "^1.2.1" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/slash": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-5.1.0.tgz", + "integrity": "sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg==", + "dev": true, + "engines": { + "node": ">=14.16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/slice-ansi": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", + "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^6.0.0", + "is-fullwidth-code-point": "^4.0.0" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/slice-ansi?sponsor=1" + } + }, + "node_modules/slice-ansi/node_modules/ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/smart-buffer": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", + "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", + "dev": true, + "engines": { + "node": ">= 6.0.0", + "npm": ">= 3.0.0" + } + }, + "node_modules/socket.io": { + "version": "4.7.5", + "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-4.7.5.tgz", + "integrity": "sha512-DmeAkF6cwM9jSfmp6Dr/5/mfMwb5Z5qRrSXLpo3Fq5SqyU8CMF15jIN4ZhfSwu35ksM1qmHZDQ/DK5XTccSTvA==", + "dev": true, + "dependencies": { + "accepts": "~1.3.4", + "base64id": "~2.0.0", + "cors": "~2.8.5", + "debug": "~4.3.2", + "engine.io": "~6.5.2", + "socket.io-adapter": "~2.5.2", + "socket.io-parser": "~4.2.4" + }, + "engines": { + "node": ">=10.2.0" + } + }, + "node_modules/socket.io-adapter": { + "version": "2.5.5", + "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-2.5.5.tgz", + "integrity": "sha512-eLDQas5dzPgOWCk9GuuJC2lBqItuhKI4uxGgo9aIV7MYbk2h9Q6uULEh8WBzThoI7l+qU9Ast9fVUmkqPP9wYg==", + "dev": true, + "dependencies": { + "debug": "~4.3.4", + "ws": "~8.17.1" + } + }, + "node_modules/socket.io-parser": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.2.4.tgz", + "integrity": "sha512-/GbIKmo8ioc+NIWIhwdecY0ge+qVBSMdgxGygevmdHj24bsfgtCmcUUcQ5ZzcylGFHsN3k4HB4Cgkl96KVnuew==", + "dev": true, + "dependencies": { + "@socket.io/component-emitter": "~3.1.0", + "debug": "~4.3.1" + }, + "engines": { + "node": ">=10.0.0" + } + }, + "node_modules/sockjs": { + "version": "0.3.24", + "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.24.tgz", + "integrity": "sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ==", + "dev": true, + "dependencies": { + "faye-websocket": "^0.11.3", + "uuid": "^8.3.2", + "websocket-driver": "^0.7.4" + } + }, + "node_modules/socks": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/socks/-/socks-2.8.3.tgz", + "integrity": "sha512-l5x7VUUWbjVFbafGLxPWkYsHIhEvmF85tbIeFZWc8ZPtoMyybuEhL7Jye/ooC4/d48FgOjSJXgsF/AJPYCW8Zw==", + "dev": true, + "dependencies": { + "ip-address": "^9.0.5", + "smart-buffer": "^4.2.0" + }, + "engines": { + "node": ">= 10.0.0", + "npm": ">= 3.0.0" + } + }, + "node_modules/socks-proxy-agent": { + "version": "8.0.4", + "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-8.0.4.tgz", + "integrity": "sha512-GNAq/eg8Udq2x0eNiFkr9gRg5bA7PXEWagQdeRX4cPSG+X/8V38v637gim9bjFptMk1QWsCTr0ttrJEiXbNnRw==", + "dev": true, + "dependencies": { + "agent-base": "^7.1.1", + "debug": "^4.3.4", + "socks": "^2.8.3" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/source-map": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", + "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "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==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-map-loader": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-5.0.0.tgz", + "integrity": "sha512-k2Dur7CbSLcAH73sBcIkV5xjPV4SzqO1NJ7+XaQl8if3VODDUj3FNchNGpqgJSKbvUfJuhVdv8K2Eu8/TNl2eA==", + "dev": true, + "dependencies": { + "iconv-lite": "^0.6.3", + "source-map-js": "^1.0.2" + }, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^5.72.1" + } + }, + "node_modules/source-map-loader/node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "dev": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dev": true, + "dependencies": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "node_modules/source-map-support/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/spdx-correct": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", + "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", + "dev": true, + "dependencies": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "node_modules/spdx-exceptions": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.5.0.tgz", + "integrity": "sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==", + "dev": true + }, + "node_modules/spdx-expression-parse": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", + "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", + "dev": true, + "dependencies": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "node_modules/spdx-license-ids": { + "version": "3.0.18", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.18.tgz", + "integrity": "sha512-xxRs31BqRYHwiMzudOrpSiHtZ8i/GeionCBDSilhYRj+9gIcI8wCZTlXZKu9vZIVqViP3dcp9qE5G6AlIaD+TQ==", + "dev": true + }, + "node_modules/spdy": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.2.tgz", + "integrity": "sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA==", + "dev": true, + "dependencies": { + "debug": "^4.1.0", + "handle-thing": "^2.0.0", + "http-deceiver": "^1.2.7", + "select-hose": "^2.0.0", + "spdy-transport": "^3.0.0" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/spdy-transport": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz", + "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==", + "dev": true, + "dependencies": { + "debug": "^4.1.0", + "detect-node": "^2.0.4", + "hpack.js": "^2.1.6", + "obuf": "^1.1.2", + "readable-stream": "^3.0.6", + "wbuf": "^1.7.3" + } + }, + "node_modules/sprintf-js": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.3.tgz", + "integrity": "sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==", + "dev": true + }, + "node_modules/ssri": { + "version": "10.0.6", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-10.0.6.tgz", + "integrity": "sha512-MGrFH9Z4NP9Iyhqn16sDtBpRRNJ0Y2hNa6D65h736fVSaPCHr4DM4sWUNvVaSuC+0OBGhwsrydQwmgfg5LncqQ==", + "dev": true, + "dependencies": { + "minipass": "^7.0.3" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/statuses": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", + "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/streamroller": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/streamroller/-/streamroller-3.1.5.tgz", + "integrity": "sha512-KFxaM7XT+irxvdqSP1LGLgNWbYN7ay5owZ3r/8t77p+EtSUAfUgtl7be3xtqtOmGUl9K9YPO2ca8133RlTjvKw==", + "dev": true, + "dependencies": { + "date-format": "^4.0.14", + "debug": "^4.3.4", + "fs-extra": "^8.1.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/string_decoder": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "dev": true, + "dependencies": { + "safe-buffer": "~5.2.0" + } + }, + "node_modules/string-width": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", + "integrity": "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ==", + "dev": true, + "dependencies": { + "emoji-regex": "^10.3.0", + "get-east-asian-width": "^1.0.0", + "strip-ansi": "^7.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/string-width-cjs": { + "name": "string-width", + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/string-width-cjs/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/string-width/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "dev": true, + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "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-ansi-cjs": { + "name": "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-final-newline": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", + "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/symbol-observable": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-4.0.0.tgz", + "integrity": "sha512-b19dMThMV4HVFynSAM1++gBHAbk2Tc/osgLIBZMKsyqh34jb2e8Os7T6ZW/Bt3pJFdBTd2JwAnAAEQV7rSNvcQ==", + "dev": true, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/tapable": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", + "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/tar": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/tar/-/tar-6.2.1.tgz", + "integrity": "sha512-DZ4yORTwrbTj/7MZYq2w+/ZFdI6OZ/f9SFHR+71gIVUZhOQPHzVCLpvRnPgyaMpfWxxk/4ONva3GQSyNIKRv6A==", + "dev": true, + "dependencies": { + "chownr": "^2.0.0", + "fs-minipass": "^2.0.0", + "minipass": "^5.0.0", + "minizlib": "^2.1.1", + "mkdirp": "^1.0.3", + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/tar/node_modules/fs-minipass": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", + "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", + "dev": true, + "dependencies": { + "minipass": "^3.0.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/tar/node_modules/fs-minipass/node_modules/minipass": { + "version": "3.3.6", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", + "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/tar/node_modules/minipass": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", + "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/tar/node_modules/mkdirp": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", + "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", + "dev": true, + "bin": { + "mkdirp": "bin/cmd.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/tar/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, + "node_modules/terser": { + "version": "5.29.2", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.29.2.tgz", + "integrity": "sha512-ZiGkhUBIM+7LwkNjXYJq8svgkd+QK3UUr0wJqY4MieaezBSAIPgbSPZyIx0idM6XWK5CMzSWa8MJIzmRcB8Caw==", + "dev": true, + "dependencies": { + "@jridgewell/source-map": "^0.3.3", + "acorn": "^8.8.2", + "commander": "^2.20.0", + "source-map-support": "~0.5.20" + }, + "bin": { + "terser": "bin/terser" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/terser-webpack-plugin": { + "version": "5.3.10", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz", + "integrity": "sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==", + "dev": true, + "dependencies": { + "@jridgewell/trace-mapping": "^0.3.20", + "jest-worker": "^27.4.5", + "schema-utils": "^3.1.1", + "serialize-javascript": "^6.0.1", + "terser": "^5.26.0" + }, + "engines": { + "node": ">= 10.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^5.1.0" + }, + "peerDependenciesMeta": { + "@swc/core": { + "optional": true + }, + "esbuild": { + "optional": true + }, + "uglify-js": { + "optional": true + } + } + }, + "node_modules/terser-webpack-plugin/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/terser-webpack-plugin/node_modules/ajv-keywords": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", + "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", + "dev": true, + "peerDependencies": { + "ajv": "^6.9.1" + } + }, + "node_modules/terser-webpack-plugin/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/terser-webpack-plugin/node_modules/schema-utils": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", + "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", + "dev": true, + "dependencies": { + "@types/json-schema": "^7.0.8", + "ajv": "^6.12.5", + "ajv-keywords": "^3.5.2" + }, + "engines": { + "node": ">= 10.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + } + }, + "node_modules/thingies": { + "version": "1.21.0", + "resolved": "https://registry.npmjs.org/thingies/-/thingies-1.21.0.tgz", + "integrity": "sha512-hsqsJsFMsV+aD4s3CWKk85ep/3I9XzYV/IXaSouJMYIoDlgyi11cBhsqYe9/geRfB0YIikBQg6raRaM+nIMP9g==", + "dev": true, + "engines": { + "node": ">=10.18" + }, + "peerDependencies": { + "tslib": "^2" + } + }, + "node_modules/thunky": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", + "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==", + "dev": true + }, + "node_modules/tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "dev": true, + "dependencies": { + "os-tmpdir": "~1.0.2" + }, + "engines": { + "node": ">=0.6.0" + } + }, + "node_modules/to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "dev": true, + "engines": { + "node": ">=0.6" + } + }, + "node_modules/tree-dump": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/tree-dump/-/tree-dump-1.0.2.tgz", + "integrity": "sha512-dpev9ABuLWdEubk+cIaI9cHwRNNDjkBBLXTwI4UCUFdQ5xXKqNXoK4FEciw/vxf+NQ7Cb7sGUyeUtORvHIdRXQ==", + "dev": true, + "engines": { + "node": ">=10.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/streamich" + }, + "peerDependencies": { + "tslib": "2" + } + }, + "node_modules/tree-kill": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", + "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", + "dev": true, + "bin": { + "tree-kill": "cli.js" + } + }, + "node_modules/tslib": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", + "integrity": "sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==" + }, + "node_modules/tuf-js": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/tuf-js/-/tuf-js-2.2.1.tgz", + "integrity": "sha512-GwIJau9XaA8nLVbUXsN3IlFi7WmQ48gBUrl3FTkkL/XLu/POhBzfmX9hd33FNMX1qAsfl6ozO1iMmW9NC8YniA==", + "dev": true, + "dependencies": { + "@tufjs/models": "2.0.1", + "debug": "^4.3.4", + "make-fetch-happen": "^13.0.1" + }, + "engines": { + "node": "^16.14.0 || >=18.0.0" + } + }, + "node_modules/type-fest": { + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/type-is": { + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", + "dev": true, + "dependencies": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/typed-assert": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/typed-assert/-/typed-assert-1.0.9.tgz", + "integrity": "sha512-KNNZtayBCtmnNmbo5mG47p1XsCyrx6iVqomjcZnec/1Y5GGARaxPs6r49RnSPeUP3YjNYiU9sQHAtY4BBvnZwg==", + "dev": true + }, + "node_modules/typescript": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.3.tgz", + "integrity": "sha512-/hreyEujaB0w76zKo6717l3L0o/qEUtRgdvUBvlkhoWeOVMjMuHNHk0BRBzikzuGDqNmPQbg5ifMEqsHLiIUcQ==", + "dev": true, + "bin": { + "tsc": "bin/tsc", + "tsserver": "bin/tsserver" + }, + "engines": { + "node": ">=14.17" + } + }, + "node_modules/ua-parser-js": { + "version": "0.7.38", + "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.38.tgz", + "integrity": "sha512-fYmIy7fKTSFAhG3fuPlubeGaMoAd6r0rSnfEsO5nEY55i26KSLt9EH7PLQiiqPUhNqYIJvSkTy1oArIcXAbPbA==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/ua-parser-js" + }, + { + "type": "paypal", + "url": "https://paypal.me/faisalman" + }, + { + "type": "github", + "url": "https://github.com/sponsors/faisalman" + } + ], + "engines": { + "node": "*" + } + }, + "node_modules/undici": { + "version": "6.19.2", + "resolved": "https://registry.npmjs.org/undici/-/undici-6.19.2.tgz", + "integrity": "sha512-JfjKqIauur3Q6biAtHJ564e3bWa8VvT+7cSiOJHFbX4Erv6CLGDpg8z+Fmg/1OI/47RA+GI2QZaF48SSaLvyBA==", + "dev": true, + "engines": { + "node": ">=18.17" + } + }, + "node_modules/undici-types": { + "version": "5.26.5", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", + "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", + "dev": true + }, + "node_modules/unicode-canonical-property-names-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", + "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-match-property-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz", + "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==", + "dev": true, + "dependencies": { + "unicode-canonical-property-names-ecmascript": "^2.0.0", + "unicode-property-aliases-ecmascript": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-match-property-value-ecmascript": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz", + "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-property-aliases-ecmascript": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz", + "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicorn-magic": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/unicorn-magic/-/unicorn-magic-0.1.0.tgz", + "integrity": "sha512-lRfVq8fE8gz6QMBuDM6a+LO3IAzTi05H6gCVaUpir2E1Rwpo4ZUog45KpNXKC/Mn3Yb9UDuHumeFTo9iV/D9FQ==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/unique-filename": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-3.0.0.tgz", + "integrity": "sha512-afXhuC55wkAmZ0P18QsVE6kp8JaxrEokN2HGIoIVv2ijHQd419H0+6EigAFcIzXeMIkcIkNBpB3L/DXB3cTS/g==", + "dev": true, + "dependencies": { + "unique-slug": "^4.0.0" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/unique-slug": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-4.0.0.tgz", + "integrity": "sha512-WrcA6AyEfqDX5bWige/4NQfPZMtASNVxdmWR76WESYQVAACSgWcR6e9i0mofqqBxYFtL4oAxPIptY73/0YE1DQ==", + "dev": true, + "dependencies": { + "imurmurhash": "^0.1.4" + }, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true, + "engines": { + "node": ">= 4.0.0" + } + }, + "node_modules/unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/update-browserslist-db": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.0.tgz", + "integrity": "sha512-EdRAaAyk2cUE1wOf2DkEhzxqOQvFOoRJFNS6NeyJ01Gp2beMRpBAINjM2iDXE3KCuKhwnvHIQCJm6ThL2Z+HzQ==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "escalade": "^3.1.2", + "picocolors": "^1.0.1" + }, + "bin": { + "update-browserslist-db": "cli.js" + }, + "peerDependencies": { + "browserslist": ">= 4.21.0" + } + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/uri-js/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/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/utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", + "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", + "dev": true, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", + "dev": true, + "bin": { + "uuid": "dist/bin/uuid" + } + }, + "node_modules/validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "dev": true, + "dependencies": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "node_modules/validate-npm-package-name": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/validate-npm-package-name/-/validate-npm-package-name-5.0.1.tgz", + "integrity": "sha512-OljLrQ9SQdOUqTaQxqL5dEfZWrXExyyWsozYlAWFawPVNuD83igl7uJD2RTkNMbniIYgt8l81eCJGIdQF7avLQ==", + "dev": true, + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, + "node_modules/vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/vite": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/vite/-/vite-5.3.2.tgz", + "integrity": "sha512-6lA7OBHBlXUxiJxbO5aAY2fsHHzDr1q7DvXYnyZycRs2Dz+dXBWuhpWHvmljTRTpQC2uvGmUFFkSHF2vGo90MA==", + "dev": true, + "dependencies": { + "esbuild": "^0.21.3", + "postcss": "^8.4.38", + "rollup": "^4.13.0" + }, + "bin": { + "vite": "bin/vite.js" + }, + "engines": { + "node": "^18.0.0 || >=20.0.0" + }, + "funding": { + "url": "https://github.com/vitejs/vite?sponsor=1" + }, + "optionalDependencies": { + "fsevents": "~2.3.3" + }, + "peerDependencies": { + "@types/node": "^18.0.0 || >=20.0.0", + "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/void-elements": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-2.0.1.tgz", + "integrity": "sha512-qZKX4RnBzH2ugr8Lxa7x+0V6XD9Sb/ouARtiasEQCHB1EVU4NXtmHsDDrx1dO4ne5fc3J6EW05BP1Dl0z0iung==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/watchpack": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.1.tgz", + "integrity": "sha512-8wrBCMtVhqcXP2Sup1ctSkga6uc2Bx0IIvKyT7yTFier5AXHooSI+QyQQAtTb7+E0IUCCKyTFmXqdqgum2XWGg==", + "dev": true, + "dependencies": { + "glob-to-regexp": "^0.4.1", + "graceful-fs": "^4.1.2" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/wbuf": { + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz", + "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==", + "dev": true, + "dependencies": { + "minimalistic-assert": "^1.0.0" + } + }, + "node_modules/wcwidth": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", + "integrity": "sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==", + "dev": true, + "dependencies": { + "defaults": "^1.0.3" + } + }, + "node_modules/weak-lru-cache": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/weak-lru-cache/-/weak-lru-cache-1.2.2.tgz", + "integrity": "sha512-DEAoo25RfSYMuTGc9vPJzZcZullwIqRDSI9LOy+fkCJPi6hykCnfKaXTuPBDuXAUcqHXyOgFtHNp/kB2FjYHbw==", + "dev": true + }, + "node_modules/webpack": { + "version": "5.92.1", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.92.1.tgz", + "integrity": "sha512-JECQ7IwJb+7fgUFBlrJzbyu3GEuNBcdqr1LD7IbSzwkSmIevTm8PF+wej3Oxuz/JFBUZ6O1o43zsPkwm1C4TmA==", + "dev": true, + "dependencies": { + "@types/eslint-scope": "^3.7.3", + "@types/estree": "^1.0.5", + "@webassemblyjs/ast": "^1.12.1", + "@webassemblyjs/wasm-edit": "^1.12.1", + "@webassemblyjs/wasm-parser": "^1.12.1", + "acorn": "^8.7.1", + "acorn-import-attributes": "^1.9.5", + "browserslist": "^4.21.10", + "chrome-trace-event": "^1.0.2", + "enhanced-resolve": "^5.17.0", + "es-module-lexer": "^1.2.1", + "eslint-scope": "5.1.1", + "events": "^3.2.0", + "glob-to-regexp": "^0.4.1", + "graceful-fs": "^4.2.11", + "json-parse-even-better-errors": "^2.3.1", + "loader-runner": "^4.2.0", + "mime-types": "^2.1.27", + "neo-async": "^2.6.2", + "schema-utils": "^3.2.0", + "tapable": "^2.1.1", + "terser-webpack-plugin": "^5.3.10", + "watchpack": "^2.4.1", + "webpack-sources": "^3.2.3" + }, + "bin": { + "webpack": "bin/webpack.js" + }, + "engines": { + "node": ">=10.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependenciesMeta": { + "webpack-cli": { + "optional": true + } + } + }, + "node_modules/webpack-dev-middleware": { + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-7.2.1.tgz", + "integrity": "sha512-hRLz+jPQXo999Nx9fXVdKlg/aehsw1ajA9skAneGmT03xwmyuhvF93p6HUKKbWhXdcERtGTzUCtIQr+2IQegrA==", + "dev": true, + "dependencies": { + "colorette": "^2.0.10", + "memfs": "^4.6.0", + "mime-types": "^2.1.31", + "on-finished": "^2.4.1", + "range-parser": "^1.2.1", + "schema-utils": "^4.0.0" + }, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^5.0.0" + }, + "peerDependenciesMeta": { + "webpack": { + "optional": true + } + } + }, + "node_modules/webpack-dev-server": { + "version": "5.0.4", + "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-5.0.4.tgz", + "integrity": "sha512-dljXhUgx3HqKP2d8J/fUMvhxGhzjeNVarDLcbO/EWMSgRizDkxHQDZQaLFL5VJY9tRBj2Gz+rvCEYYvhbqPHNA==", + "dev": true, + "dependencies": { + "@types/bonjour": "^3.5.13", + "@types/connect-history-api-fallback": "^1.5.4", + "@types/express": "^4.17.21", + "@types/serve-index": "^1.9.4", + "@types/serve-static": "^1.15.5", + "@types/sockjs": "^0.3.36", + "@types/ws": "^8.5.10", + "ansi-html-community": "^0.0.8", + "bonjour-service": "^1.2.1", + "chokidar": "^3.6.0", + "colorette": "^2.0.10", + "compression": "^1.7.4", + "connect-history-api-fallback": "^2.0.0", + "default-gateway": "^6.0.3", + "express": "^4.17.3", + "graceful-fs": "^4.2.6", + "html-entities": "^2.4.0", + "http-proxy-middleware": "^2.0.3", + "ipaddr.js": "^2.1.0", + "launch-editor": "^2.6.1", + "open": "^10.0.3", + "p-retry": "^6.2.0", + "rimraf": "^5.0.5", + "schema-utils": "^4.2.0", + "selfsigned": "^2.4.1", + "serve-index": "^1.9.1", + "sockjs": "^0.3.24", + "spdy": "^4.0.2", + "webpack-dev-middleware": "^7.1.0", + "ws": "^8.16.0" + }, + "bin": { + "webpack-dev-server": "bin/webpack-dev-server.js" + }, + "engines": { + "node": ">= 18.12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^5.0.0" + }, + "peerDependenciesMeta": { + "webpack": { + "optional": true + }, + "webpack-cli": { + "optional": true + } + } + }, + "node_modules/webpack-dev-server/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/webpack-dev-server/node_modules/glob": { + "version": "10.4.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", + "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", + "dev": true, + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^3.1.2", + "minimatch": "^9.0.4", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^1.11.1" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/webpack-dev-server/node_modules/http-proxy-middleware": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz", + "integrity": "sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw==", + "dev": true, + "dependencies": { + "@types/http-proxy": "^1.17.8", + "http-proxy": "^1.18.1", + "is-glob": "^4.0.1", + "is-plain-obj": "^3.0.0", + "micromatch": "^4.0.2" + }, + "engines": { + "node": ">=12.0.0" + }, + "peerDependencies": { + "@types/express": "^4.17.13" + }, + "peerDependenciesMeta": { + "@types/express": { + "optional": true + } + } + }, + "node_modules/webpack-dev-server/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/webpack-dev-server/node_modules/rimraf": { + "version": "5.0.9", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-5.0.9.tgz", + "integrity": "sha512-3i7b8OcswU6CpU8Ej89quJD4O98id7TtVM5U4Mybh84zQXdrFmDLouWBEEaD/QfO3gDDfH+AGFCGsR7kngzQnA==", + "dev": true, + "dependencies": { + "glob": "^10.3.7" + }, + "bin": { + "rimraf": "dist/esm/bin.mjs" + }, + "engines": { + "node": "14 >=14.20 || 16 >=16.20 || >=18" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/webpack-merge": { + "version": "5.10.0", + "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-5.10.0.tgz", + "integrity": "sha512-+4zXKdx7UnO+1jaN4l2lHVD+mFvnlZQP/6ljaJVb4SZiwIKeUnrT5l0gkT8z+n4hKpC+jpOv6O9R+gLtag7pSA==", + "dev": true, + "dependencies": { + "clone-deep": "^4.0.1", + "flat": "^5.0.2", + "wildcard": "^2.0.0" + }, + "engines": { + "node": ">=10.0.0" + } + }, + "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-subresource-integrity": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/webpack-subresource-integrity/-/webpack-subresource-integrity-5.1.0.tgz", + "integrity": "sha512-sacXoX+xd8r4WKsy9MvH/q/vBtEHr86cpImXwyg74pFIpERKt6FmB8cXpeuh0ZLgclOlHI4Wcll7+R5L02xk9Q==", + "dev": true, + "dependencies": { + "typed-assert": "^1.0.8" + }, + "engines": { + "node": ">= 12" + }, + "peerDependencies": { + "html-webpack-plugin": ">= 5.0.0-beta.1 < 6", + "webpack": "^5.12.0" + }, + "peerDependenciesMeta": { + "html-webpack-plugin": { + "optional": true + } + } + }, + "node_modules/webpack/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/webpack/node_modules/ajv-keywords": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", + "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", + "dev": true, + "peerDependencies": { + "ajv": "^6.9.1" + } + }, + "node_modules/webpack/node_modules/json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true + }, + "node_modules/webpack/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/webpack/node_modules/schema-utils": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", + "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", + "dev": true, + "dependencies": { + "@types/json-schema": "^7.0.8", + "ajv": "^6.12.5", + "ajv-keywords": "^3.5.2" + }, + "engines": { + "node": ">= 10.13.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + } + }, + "node_modules/websocket-driver": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", + "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", + "dev": true, + "dependencies": { + "http-parser-js": ">=0.5.1", + "safe-buffer": ">=5.1.0", + "websocket-extensions": ">=0.1.1" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/websocket-extensions": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", + "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "which": "bin/which" + } + }, + "node_modules/wildcard": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/wildcard/-/wildcard-2.0.1.tgz", + "integrity": "sha512-CC1bOL87PIWSBhDcTrdeLo6eGT7mCFtrg0uIJtqJUFyK+eJnzl8A1niH56uu7KMa5XFrtiV+AQuHO3n7DsHnLQ==", + "dev": true + }, + "node_modules/wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", + "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi-cjs": { + "name": "wrap-ansi", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/wrap-ansi-cjs/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/wrap-ansi-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/wrap-ansi-cjs/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/wrap-ansi/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/wrap-ansi/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/wrap-ansi/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/wrap-ansi/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/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/ws": { + "version": "8.17.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.1.tgz", + "integrity": "sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==", + "dev": true, + "engines": { + "node": ">=10.0.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": ">=5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "dev": true + }, + "node_modules/yargs": { + "version": "17.7.2", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", + "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", + "dev": true, + "dependencies": { + "cliui": "^8.0.1", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.3", + "y18n": "^5.0.5", + "yargs-parser": "^21.1.1" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/yargs-parser": { + "version": "21.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", + "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", + "dev": true, + "engines": { + "node": ">=12" + } + }, + "node_modules/yargs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/yargs/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yocto-queue": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-1.1.1.tgz", + "integrity": "sha512-b4JR1PFR10y1mKjhHY9LaGo6tmrgjit7hxVIeAmyMw3jegXR4dhYqLaQF5zMXZxY7tLpMyJeLjr1C4rLmkVe8g==", + "dev": true, + "engines": { + "node": ">=12.20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/yoctocolors-cjs": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yoctocolors-cjs/-/yoctocolors-cjs-2.1.2.tgz", + "integrity": "sha512-cYVsTjKl8b+FrnidjibDWskAv7UKOfcwaVZdp/it9n1s9fU3IkgDbhdIRKCW4JDsAlECJY0ytoVPT3sK6kideA==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/zone.js": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/zone.js/-/zone.js-0.14.7.tgz", + "integrity": "sha512-0w6DGkX2BPuiK/NLf+4A8FLE43QwBfuqz2dVgi/40Rj1WmqUskCqj329O/pwrqFJLG5X8wkeG2RhIAro441xtg==" + } + } +} diff --git a/webapp/package.json b/webapp/package.json new file mode 100644 index 00000000..7154c9c7 --- /dev/null +++ b/webapp/package.json @@ -0,0 +1,38 @@ +{ + "name": "webapp", + "version": "0.0.0", + "scripts": { + "ng": "ng", + "start": "ng serve", + "build": "ng build", + "watch": "ng build --watch --configuration development", + "test": "ng test" + }, + "private": true, + "dependencies": { + "@angular/animations": "^18.1.0", + "@angular/common": "^18.1.0", + "@angular/compiler": "^18.1.0", + "@angular/core": "^18.1.0", + "@angular/forms": "^18.1.0", + "@angular/platform-browser": "^18.1.0", + "@angular/platform-browser-dynamic": "^18.1.0", + "@angular/router": "^18.1.0", + "rxjs": "~7.8.0", + "tslib": "^2.3.0", + "zone.js": "~0.14.3" + }, + "devDependencies": { + "@angular-devkit/build-angular": "^18.1.0", + "@angular/cli": "^18.1.0", + "@angular/compiler-cli": "^18.1.0", + "@types/jasmine": "~5.1.0", + "jasmine-core": "~5.1.0", + "karma": "~6.4.0", + "karma-chrome-launcher": "~3.2.0", + "karma-coverage": "~2.2.0", + "karma-jasmine": "~5.1.0", + "karma-jasmine-html-reporter": "~2.1.0", + "typescript": "~5.5.2" + } +} diff --git a/webapp/public/favicon.ico b/webapp/public/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..180bb1ae642aa6b72eeb17211d7b96bf8f3e2f67 GIT binary patch literal 176916 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ဤ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 literal 0 HcmV?d00001 diff --git a/webapp/src/app/app.component.html b/webapp/src/app/app.component.html new file mode 100644 index 00000000..36093e18 --- /dev/null +++ b/webapp/src/app/app.component.html @@ -0,0 +1,336 @@ + + + + + + + + + + + +
+
+
+ +

Hello, {{ title }}

+

Congratulations! Your app is running. 🎉

+
+ +
+
+ @for (item of [ + { title: 'Explore the Docs', link: 'https://angular.dev' }, + { title: 'Learn with Tutorials', link: 'https://angular.dev/tutorials' }, + { title: 'CLI Docs', link: 'https://angular.dev/tools/cli' }, + { title: 'Angular Language Service', link: 'https://angular.dev/tools/language-service' }, + { title: 'Angular DevTools', link: 'https://angular.dev/tools/devtools' }, + ]; track item.title) { + + {{ item.title }} + + + + + } +
+ +
+
+
+ + + + + + + + + + + diff --git a/webapp/src/app/app.component.ts b/webapp/src/app/app.component.ts new file mode 100644 index 00000000..e85012f9 --- /dev/null +++ b/webapp/src/app/app.component.ts @@ -0,0 +1,13 @@ +import { Component } from '@angular/core'; +import { RouterOutlet } from '@angular/router'; + +@Component({ + selector: 'app-root', + standalone: true, + imports: [RouterOutlet], + templateUrl: './app.component.html', + styles: [], +}) +export class AppComponent { + title = 'webapp'; +} diff --git a/webapp/src/app/app.config.ts b/webapp/src/app/app.config.ts new file mode 100644 index 00000000..a1e7d6f8 --- /dev/null +++ b/webapp/src/app/app.config.ts @@ -0,0 +1,8 @@ +import { ApplicationConfig, provideZoneChangeDetection } from '@angular/core'; +import { provideRouter } from '@angular/router'; + +import { routes } from './app.routes'; + +export const appConfig: ApplicationConfig = { + providers: [provideZoneChangeDetection({ eventCoalescing: true }), provideRouter(routes)] +}; diff --git a/webapp/src/app/app.routes.ts b/webapp/src/app/app.routes.ts new file mode 100644 index 00000000..dc39edb5 --- /dev/null +++ b/webapp/src/app/app.routes.ts @@ -0,0 +1,3 @@ +import { Routes } from '@angular/router'; + +export const routes: Routes = []; diff --git a/webapp/src/app/hello-world/hello-world.component.html b/webapp/src/app/hello-world/hello-world.component.html new file mode 100644 index 00000000..589144d4 --- /dev/null +++ b/webapp/src/app/hello-world/hello-world.component.html @@ -0,0 +1 @@ +

hello-world works!

diff --git a/webapp/src/app/hello-world/hello-world.component.ts b/webapp/src/app/hello-world/hello-world.component.ts new file mode 100644 index 00000000..bda63d40 --- /dev/null +++ b/webapp/src/app/hello-world/hello-world.component.ts @@ -0,0 +1,13 @@ +import { ChangeDetectionStrategy, Component } from '@angular/core'; + +@Component({ + selector: 'hello-world', + standalone: true, + imports: [], + templateUrl: './hello-world.component.html', + styles: ``, + changeDetection: ChangeDetectionStrategy.OnPush +}) +export class HelloWorldComponent { + +} diff --git a/webapp/src/index.html b/webapp/src/index.html new file mode 100644 index 00000000..5b75346d --- /dev/null +++ b/webapp/src/index.html @@ -0,0 +1,13 @@ + + + + + Webapp + + + + + + + + diff --git a/webapp/src/main.ts b/webapp/src/main.ts new file mode 100644 index 00000000..35b00f34 --- /dev/null +++ b/webapp/src/main.ts @@ -0,0 +1,6 @@ +import { bootstrapApplication } from '@angular/platform-browser'; +import { appConfig } from './app/app.config'; +import { AppComponent } from './app/app.component'; + +bootstrapApplication(AppComponent, appConfig) + .catch((err) => console.error(err)); diff --git a/webapp/src/styles.sass b/webapp/src/styles.sass new file mode 100644 index 00000000..90d4ee00 --- /dev/null +++ b/webapp/src/styles.sass @@ -0,0 +1 @@ +/* You can add global styles to this file, and also import other style files */ diff --git a/webapp/tsconfig.app.json b/webapp/tsconfig.app.json new file mode 100644 index 00000000..3775b37e --- /dev/null +++ b/webapp/tsconfig.app.json @@ -0,0 +1,15 @@ +/* To learn more about Typescript configuration file: https://www.typescriptlang.org/docs/handbook/tsconfig-json.html. */ +/* To learn more about Angular compiler options: https://angular.dev/reference/configs/angular-compiler-options. */ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "./out-tsc/app", + "types": [] + }, + "files": [ + "src/main.ts" + ], + "include": [ + "src/**/*.d.ts" + ] +} diff --git a/webapp/tsconfig.json b/webapp/tsconfig.json new file mode 100644 index 00000000..a9ae8b06 --- /dev/null +++ b/webapp/tsconfig.json @@ -0,0 +1,32 @@ +/* To learn more about Typescript configuration file: https://www.typescriptlang.org/docs/handbook/tsconfig-json.html. */ +/* To learn more about Angular compiler options: https://angular.dev/reference/configs/angular-compiler-options. */ +{ + "compileOnSave": false, + "compilerOptions": { + "outDir": "./dist/out-tsc", + "strict": true, + "noImplicitOverride": true, + "noPropertyAccessFromIndexSignature": true, + "noImplicitReturns": true, + "noFallthroughCasesInSwitch": true, + "skipLibCheck": true, + "esModuleInterop": true, + "sourceMap": true, + "declaration": false, + "experimentalDecorators": true, + "moduleResolution": "bundler", + "importHelpers": true, + "target": "ES2022", + "module": "ES2022", + "lib": [ + "ES2022", + "dom" + ] + }, + "angularCompilerOptions": { + "enableI18nLegacyMessageIdFormat": false, + "strictInjectionParameters": true, + "strictInputAccessModifiers": true, + "strictTemplates": true + } +} diff --git a/webapp/tsconfig.spec.json b/webapp/tsconfig.spec.json new file mode 100644 index 00000000..5fb748d9 --- /dev/null +++ b/webapp/tsconfig.spec.json @@ -0,0 +1,15 @@ +/* To learn more about Typescript configuration file: https://www.typescriptlang.org/docs/handbook/tsconfig-json.html. */ +/* To learn more about Angular compiler options: https://angular.dev/reference/configs/angular-compiler-options. */ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "./out-tsc/spec", + "types": [ + "jasmine" + ] + }, + "include": [ + "src/**/*.spec.ts", + "src/**/*.d.ts" + ] +} From e4c4156a26d2303d94c66e9251af3b2cd33ba485 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Sun, 14 Jul 2024 18:09:18 +0200 Subject: [PATCH 02/12] change to zoneless change detection --- webapp/angular.json | 7 ++----- webapp/src/app/app.component.html | 1 + webapp/src/app/app.component.ts | 3 ++- webapp/src/app/app.config.ts | 7 +++++-- webapp/src/app/hello-world/hello-world.component.ts | 5 +---- 5 files changed, 11 insertions(+), 12 deletions(-) diff --git a/webapp/angular.json b/webapp/angular.json index c44e2c1e..3a6bb920 100644 --- a/webapp/angular.json +++ b/webapp/angular.json @@ -10,8 +10,7 @@ "inlineStyle": true, "style": "sass", "skipTests": true, - "standalone": true, - "changeDetection": "OnPush" + "standalone": true }, "@schematics/angular:class": { "skipTests": true @@ -45,9 +44,7 @@ "outputPath": "dist/webapp", "index": "src/index.html", "browser": "src/main.ts", - "polyfills": [ - "zone.js" - ], + "polyfills": [], "tsConfig": "tsconfig.app.json", "inlineStyleLanguage": "sass", "assets": [ diff --git a/webapp/src/app/app.component.html b/webapp/src/app/app.component.html index 36093e18..98744693 100644 --- a/webapp/src/app/app.component.html +++ b/webapp/src/app/app.component.html @@ -332,5 +332,6 @@

Hello, {{ title }}

+ diff --git a/webapp/src/app/app.component.ts b/webapp/src/app/app.component.ts index e85012f9..a21954e4 100644 --- a/webapp/src/app/app.component.ts +++ b/webapp/src/app/app.component.ts @@ -1,10 +1,11 @@ import { Component } from '@angular/core'; import { RouterOutlet } from '@angular/router'; +import { HelloWorldComponent } from './hello-world/hello-world.component'; @Component({ selector: 'app-root', standalone: true, - imports: [RouterOutlet], + imports: [RouterOutlet, HelloWorldComponent], templateUrl: './app.component.html', styles: [], }) diff --git a/webapp/src/app/app.config.ts b/webapp/src/app/app.config.ts index a1e7d6f8..e68b6224 100644 --- a/webapp/src/app/app.config.ts +++ b/webapp/src/app/app.config.ts @@ -1,8 +1,11 @@ -import { ApplicationConfig, provideZoneChangeDetection } from '@angular/core'; +import { ApplicationConfig, provideExperimentalZonelessChangeDetection } from '@angular/core'; import { provideRouter } from '@angular/router'; import { routes } from './app.routes'; export const appConfig: ApplicationConfig = { - providers: [provideZoneChangeDetection({ eventCoalescing: true }), provideRouter(routes)] + providers: [ + provideExperimentalZonelessChangeDetection(), + provideRouter(routes) + ] }; diff --git a/webapp/src/app/hello-world/hello-world.component.ts b/webapp/src/app/hello-world/hello-world.component.ts index bda63d40..643266c7 100644 --- a/webapp/src/app/hello-world/hello-world.component.ts +++ b/webapp/src/app/hello-world/hello-world.component.ts @@ -1,12 +1,9 @@ -import { ChangeDetectionStrategy, Component } from '@angular/core'; +import { Component } from '@angular/core'; @Component({ selector: 'hello-world', standalone: true, - imports: [], templateUrl: './hello-world.component.html', - styles: ``, - changeDetection: ChangeDetectionStrategy.OnPush }) export class HelloWorldComponent { From 567868892c182ad5f790936e5eb344c81447ccbb Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Sun, 14 Jul 2024 18:32:01 +0200 Subject: [PATCH 03/12] add tailwindcss --- webapp/angular.json | 10 +- webapp/package-lock.json | 1237 ++++++----------- webapp/package.json | 46 +- webapp/postcss.config.js | 6 + .../hello-world/hello-world.component.html | 2 +- webapp/src/styles.css | 3 + webapp/src/styles.sass | 1 - webapp/tailwind.config.js | 9 + 8 files changed, 465 insertions(+), 849 deletions(-) create mode 100644 webapp/postcss.config.js create mode 100644 webapp/src/styles.css delete mode 100644 webapp/src/styles.sass create mode 100644 webapp/tailwind.config.js diff --git a/webapp/angular.json b/webapp/angular.json index 3a6bb920..f72a9968 100644 --- a/webapp/angular.json +++ b/webapp/angular.json @@ -8,7 +8,7 @@ "schematics": { "@schematics/angular:component": { "inlineStyle": true, - "style": "sass", + "style": "css", "skipTests": true, "standalone": true }, @@ -46,7 +46,7 @@ "browser": "src/main.ts", "polyfills": [], "tsConfig": "tsconfig.app.json", - "inlineStyleLanguage": "sass", + "inlineStyleLanguage": "css", "assets": [ { "glob": "**/*", @@ -54,7 +54,7 @@ } ], "styles": [ - "src/styles.sass" + "src/styles.css" ], "scripts": [] }, @@ -105,7 +105,7 @@ "zone.js/testing" ], "tsConfig": "tsconfig.spec.json", - "inlineStyleLanguage": "sass", + "inlineStyleLanguage": "css", "assets": [ { "glob": "**/*", @@ -113,7 +113,7 @@ } ], "styles": [ - "src/styles.sass" + "src/styles.css" ], "scripts": [] } diff --git a/webapp/package-lock.json b/webapp/package-lock.json index 42a8d9ea..0b513fdf 100644 --- a/webapp/package-lock.json +++ b/webapp/package-lock.json @@ -8,30 +8,43 @@ "name": "webapp", "version": "0.0.0", "dependencies": { - "@angular/animations": "^18.1.0", - "@angular/common": "^18.1.0", - "@angular/compiler": "^18.1.0", - "@angular/core": "^18.1.0", - "@angular/forms": "^18.1.0", - "@angular/platform-browser": "^18.1.0", - "@angular/platform-browser-dynamic": "^18.1.0", - "@angular/router": "^18.1.0", - "rxjs": "~7.8.0", - "tslib": "^2.3.0", - "zone.js": "~0.14.3" + "@angular/animations": "18.1.0", + "@angular/common": "18.1.0", + "@angular/compiler": "18.1.0", + "@angular/core": "18.1.0", + "@angular/forms": "18.1.0", + "@angular/platform-browser": "18.1.0", + "@angular/platform-browser-dynamic": "18.1.0", + "@angular/router": "18.1.0", + "autoprefixer": "10.4.19", + "postcss": "8.4.39", + "rxjs": "7.8.1", + "tailwindcss": "3.4.4", + "tslib": "2.6.3" }, "devDependencies": { - "@angular-devkit/build-angular": "^18.1.0", - "@angular/cli": "^18.1.0", - "@angular/compiler-cli": "^18.1.0", - "@types/jasmine": "~5.1.0", - "jasmine-core": "~5.1.0", - "karma": "~6.4.0", - "karma-chrome-launcher": "~3.2.0", - "karma-coverage": "~2.2.0", - "karma-jasmine": "~5.1.0", - "karma-jasmine-html-reporter": "~2.1.0", - "typescript": "~5.5.2" + "@angular-devkit/build-angular": "18.1.0", + "@angular/cli": "18.1.0", + "@angular/compiler-cli": "18.1.0", + "@types/jasmine": "5.1.4", + "jasmine-core": "5.1.2", + "karma": "6.4.3", + "karma-chrome-launcher": "3.2.0", + "karma-coverage": "2.2.1", + "karma-jasmine": "5.1.0", + "karma-jasmine-html-reporter": "2.1.0", + "typescript": "5.5.3" + } + }, + "node_modules/@alloc/quick-lru": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@alloc/quick-lru/-/quick-lru-5.2.0.tgz", + "integrity": "sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/@ampproject/remapping": { @@ -191,6 +204,34 @@ } } }, + "node_modules/@angular-devkit/build-angular/node_modules/postcss": { + "version": "8.4.38", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", + "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.0.0", + "source-map-js": "^1.2.0" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, "node_modules/@angular-devkit/build-webpack": { "version": "0.1801.0", "resolved": "https://registry.npmjs.org/@angular-devkit/build-webpack/-/build-webpack-0.1801.0.tgz", @@ -2310,372 +2351,20 @@ "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==", "dev": true, "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/@esbuild/aix-ppc64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", - "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", - "cpu": [ - "ppc64" - ], - "dev": true, - "optional": true, - "os": [ - "aix" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/android-arm": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", - "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", - "cpu": [ - "arm" - ], - "dev": true, - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/android-arm64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", - "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/android-x64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", - "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/darwin-arm64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", - "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/darwin-x64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", - "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/freebsd-arm64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", - "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "freebsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/freebsd-x64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", - "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "freebsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-arm": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", - "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", - "cpu": [ - "arm" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-arm64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", - "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-ia32": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", - "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", - "cpu": [ - "ia32" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-loong64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", - "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", - "cpu": [ - "loong64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-mips64el": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", - "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", - "cpu": [ - "mips64el" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-ppc64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", - "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", - "cpu": [ - "ppc64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-riscv64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", - "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", - "cpu": [ - "riscv64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-s390x": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", - "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", - "cpu": [ - "s390x" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-x64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", - "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/netbsd-x64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", - "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "netbsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/openbsd-x64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", - "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "openbsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/sunos-x64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", - "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "sunos" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/win32-arm64": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", - "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/win32-ia32": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", - "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", - "cpu": [ - "ia32" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">=12" + "node": ">=10.0.0" } }, - "node_modules/@esbuild/win32-x64": { + "node_modules/@esbuild/darwin-arm64": { "version": "0.21.5", - "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", - "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", + "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", "cpu": [ - "x64" + "arm64" ], "dev": true, "optional": true, "os": [ - "win32" + "darwin" ], "engines": { "node": ">=12" @@ -3031,7 +2720,6 @@ "version": "8.0.2", "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", - "dev": true, "dependencies": { "string-width": "^5.1.2", "string-width-cjs": "npm:string-width@^4.2.0", @@ -3048,7 +2736,6 @@ "version": "6.0.1", "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", - "dev": true, "engines": { "node": ">=12" }, @@ -3060,7 +2747,6 @@ "version": "6.2.1", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", - "dev": true, "engines": { "node": ">=12" }, @@ -3071,14 +2757,12 @@ "node_modules/@isaacs/cliui/node_modules/emoji-regex": { "version": "9.2.2", "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", - "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", - "dev": true + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" }, "node_modules/@isaacs/cliui/node_modules/string-width": { "version": "5.1.2", "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", - "dev": true, "dependencies": { "eastasianwidth": "^0.2.0", "emoji-regex": "^9.2.2", @@ -3095,7 +2779,6 @@ "version": "7.1.0", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", - "dev": true, "dependencies": { "ansi-regex": "^6.0.1" }, @@ -3110,7 +2793,6 @@ "version": "8.1.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", - "dev": true, "dependencies": { "ansi-styles": "^6.1.0", "string-width": "^5.0.1", @@ -3136,7 +2818,6 @@ "version": "0.3.5", "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", - "dev": true, "dependencies": { "@jridgewell/set-array": "^1.2.1", "@jridgewell/sourcemap-codec": "^1.4.10", @@ -3150,7 +2831,6 @@ "version": "3.1.2", "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", - "dev": true, "engines": { "node": ">=6.0.0" } @@ -3159,7 +2839,6 @@ "version": "1.2.1", "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", - "dev": true, "engines": { "node": ">=6.0.0" } @@ -3177,14 +2856,12 @@ "node_modules/@jridgewell/sourcemap-codec": { "version": "1.5.0", "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", - "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", - "dev": true + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==" }, "node_modules/@jridgewell/trace-mapping": { "version": "0.3.25", "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", - "dev": true, "dependencies": { "@jridgewell/resolve-uri": "^3.1.0", "@jridgewell/sourcemap-codec": "^1.4.14" @@ -3278,71 +2955,6 @@ "darwin" ] }, - "node_modules/@lmdb/lmdb-darwin-x64": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/@lmdb/lmdb-darwin-x64/-/lmdb-darwin-x64-3.0.12.tgz", - "integrity": "sha512-qOt0hAhj2ZLY6aEWu85rzt5zcyCAQITMhCMEPNlo1tuYekpVAdkQNiwXxEkCjBYvwTskvXuwXOOUpjuSc+aJnA==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "darwin" - ] - }, - "node_modules/@lmdb/lmdb-linux-arm": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/@lmdb/lmdb-linux-arm/-/lmdb-linux-arm-3.0.12.tgz", - "integrity": "sha512-Ggd/UXpE+alMncbELCXA3OKpDj9bDBR3qVO7WRTxstloDglRAHfZmUJgTkeaNKjFO1JHqS7AKy0jba9XebZB1w==", - "cpu": [ - "arm" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@lmdb/lmdb-linux-arm64": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/@lmdb/lmdb-linux-arm64/-/lmdb-linux-arm64-3.0.12.tgz", - "integrity": "sha512-Qy4cFXFe9h1wAWMsojex8x1ifvw2kqiZv686YiRTdQEzAfc3vJASHFcD/QejHUCx7YHMYdnUoCS45rG2AiGDTQ==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@lmdb/lmdb-linux-x64": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/@lmdb/lmdb-linux-x64/-/lmdb-linux-x64-3.0.12.tgz", - "integrity": "sha512-c+noT9IofktxktFllKHFmci8ka2SYGSLN17pj/KSl1hg7mmfAiGp4xxFxEwMLTb+SX95vP1DFiR++1I3WLVxvA==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@lmdb/lmdb-win32-x64": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/@lmdb/lmdb-win32-x64/-/lmdb-win32-x64-3.0.12.tgz", - "integrity": "sha512-CO3MFV8gUx16NU/CyyuumAKblESwvoGVA2XhQKZ976OTOxaTbb8F8D3f0iiZ4MYqsN74jIrFuCmXpPnpjbhfOQ==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ] - }, "node_modules/@msgpackr-extract/msgpackr-extract-darwin-arm64": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-darwin-arm64/-/msgpackr-extract-darwin-arm64-3.0.3.tgz", @@ -3356,71 +2968,6 @@ "darwin" ] }, - "node_modules/@msgpackr-extract/msgpackr-extract-darwin-x64": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-darwin-x64/-/msgpackr-extract-darwin-x64-3.0.3.tgz", - "integrity": "sha512-mdzd3AVzYKuUmiWOQ8GNhl64/IoFGol569zNRdkLReh6LRLHOXxU4U8eq0JwaD8iFHdVGqSy4IjFL4reoWCDFw==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "darwin" - ] - }, - "node_modules/@msgpackr-extract/msgpackr-extract-linux-arm": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-arm/-/msgpackr-extract-linux-arm-3.0.3.tgz", - "integrity": "sha512-fg0uy/dG/nZEXfYilKoRe7yALaNmHoYeIoJuJ7KJ+YyU2bvY8vPv27f7UKhGRpY6euFYqEVhxCFZgAUNQBM3nw==", - "cpu": [ - "arm" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@msgpackr-extract/msgpackr-extract-linux-arm64": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-arm64/-/msgpackr-extract-linux-arm64-3.0.3.tgz", - "integrity": "sha512-YxQL+ax0XqBJDZiKimS2XQaf+2wDGVa1enVRGzEvLLVFeqa5kx2bWbtcSXgsxjQB7nRqqIGFIcLteF/sHeVtQg==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@msgpackr-extract/msgpackr-extract-linux-x64": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-x64/-/msgpackr-extract-linux-x64-3.0.3.tgz", - "integrity": "sha512-cvwNfbP07pKUfq1uH+S6KJ7dT9K8WOE4ZiAcsrSes+UY55E/0jLYc+vq+DO7jlmqRb5zAggExKm0H7O/CBaesg==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@msgpackr-extract/msgpackr-extract-win32-x64": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-win32-x64/-/msgpackr-extract-win32-x64-3.0.3.tgz", - "integrity": "sha512-x0fWaQtYp4E6sktbsdAqnehxDgEc/VwM7uLsRCYWaiGu0ykYdZPiS8zCWdnjHwyiumousxfBm4SO31eXqwEZhQ==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ] - }, "node_modules/@ngtools/webpack": { "version": "18.1.0", "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-18.1.0.tgz", @@ -3441,7 +2988,6 @@ "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" @@ -3454,7 +3000,6 @@ "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" } @@ -3463,7 +3008,6 @@ "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" @@ -3733,38 +3277,11 @@ "version": "0.11.0", "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", - "dev": true, "optional": true, "engines": { "node": ">=14" } }, - "node_modules/@rollup/rollup-android-arm-eabi": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.18.0.tgz", - "integrity": "sha512-Tya6xypR10giZV1XzxmH5wr25VcZSncG0pZIjfePT0OVBvqNEurzValetGNarVrGiq66EBVAFn15iYX4w6FKgQ==", - "cpu": [ - "arm" - ], - "dev": true, - "optional": true, - "os": [ - "android" - ] - }, - "node_modules/@rollup/rollup-android-arm64": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.18.0.tgz", - "integrity": "sha512-avCea0RAP03lTsDhEyfy+hpfr85KfyTctMADqHVhLAF3MlIkq83CP8UfAHUssgXTYd+6er6PaAhx/QGv4L1EiA==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "android" - ] - }, "node_modules/@rollup/rollup-darwin-arm64": { "version": "4.18.0", "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.18.0.tgz", @@ -3778,175 +3295,6 @@ "darwin" ] }, - "node_modules/@rollup/rollup-darwin-x64": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.18.0.tgz", - "integrity": "sha512-n2LMsUz7Ynu7DoQrSQkBf8iNrjOGyPLrdSg802vk6XT3FtsgX6JbE8IHRvposskFm9SNxzkLYGSq9QdpLYpRNA==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "darwin" - ] - }, - "node_modules/@rollup/rollup-linux-arm-gnueabihf": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.18.0.tgz", - "integrity": "sha512-C/zbRYRXFjWvz9Z4haRxcTdnkPt1BtCkz+7RtBSuNmKzMzp3ZxdM28Mpccn6pt28/UWUCTXa+b0Mx1k3g6NOMA==", - "cpu": [ - "arm" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-arm-musleabihf": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.18.0.tgz", - "integrity": "sha512-l3m9ewPgjQSXrUMHg93vt0hYCGnrMOcUpTz6FLtbwljo2HluS4zTXFy2571YQbisTnfTKPZ01u/ukJdQTLGh9A==", - "cpu": [ - "arm" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-arm64-gnu": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.18.0.tgz", - "integrity": "sha512-rJ5D47d8WD7J+7STKdCUAgmQk49xuFrRi9pZkWoRD1UeSMakbcepWXPF8ycChBoAqs1pb2wzvbY6Q33WmN2ftw==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-arm64-musl": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.18.0.tgz", - "integrity": "sha512-be6Yx37b24ZwxQ+wOQXXLZqpq4jTckJhtGlWGZs68TgdKXJgw54lUUoFYrg6Zs/kjzAQwEwYbp8JxZVzZLRepQ==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.18.0.tgz", - "integrity": "sha512-hNVMQK+qrA9Todu9+wqrXOHxFiD5YmdEi3paj6vP02Kx1hjd2LLYR2eaN7DsEshg09+9uzWi2W18MJDlG0cxJA==", - "cpu": [ - "ppc64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-riscv64-gnu": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.18.0.tgz", - "integrity": "sha512-ROCM7i+m1NfdrsmvwSzoxp9HFtmKGHEqu5NNDiZWQtXLA8S5HBCkVvKAxJ8U+CVctHwV2Gb5VUaK7UAkzhDjlg==", - "cpu": [ - "riscv64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-s390x-gnu": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.18.0.tgz", - "integrity": "sha512-0UyyRHyDN42QL+NbqevXIIUnKA47A+45WyasO+y2bGJ1mhQrfrtXUpTxCOrfxCR4esV3/RLYyucGVPiUsO8xjg==", - "cpu": [ - "s390x" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-x64-gnu": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.18.0.tgz", - "integrity": "sha512-xuglR2rBVHA5UsI8h8UbX4VJ470PtGCf5Vpswh7p2ukaqBGFTnsfzxUBetoWBWymHMxbIG0Cmx7Y9qDZzr648w==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-linux-x64-musl": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.18.0.tgz", - "integrity": "sha512-LKaqQL9osY/ir2geuLVvRRs+utWUNilzdE90TpyoX0eNqPzWjRm14oMEE+YLve4k/NAqCdPkGYDaDF5Sw+xBfg==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "linux" - ] - }, - "node_modules/@rollup/rollup-win32-arm64-msvc": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.18.0.tgz", - "integrity": "sha512-7J6TkZQFGo9qBKH0pk2cEVSRhJbL6MtfWxth7Y5YmZs57Pi+4x6c2dStAUvaQkHQLnEQv1jzBUW43GvZW8OFqA==", - "cpu": [ - "arm64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ] - }, - "node_modules/@rollup/rollup-win32-ia32-msvc": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.18.0.tgz", - "integrity": "sha512-Txjh+IxBPbkUB9+SXZMpv+b/vnTEtFyfWZgJ6iyCmt2tdx0OF5WhFowLmnh8ENGNpfUlUZkdI//4IEmhwPieNg==", - "cpu": [ - "ia32" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ] - }, - "node_modules/@rollup/rollup-win32-x64-msvc": { - "version": "4.18.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.18.0.tgz", - "integrity": "sha512-UOo5FdvOL0+eIVTgS4tIdbW+TtnBLWg1YBCcU2KWM7nuNwRz9bksDX1bekJJCpu25N1DVWaCwnT39dVQxzqS8g==", - "cpu": [ - "x64" - ], - "dev": true, - "optional": true, - "os": [ - "win32" - ] - }, "node_modules/@schematics/angular": { "version": "18.1.0", "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-18.1.0.tgz", @@ -4692,7 +4040,6 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, "engines": { "node": ">=8" } @@ -4709,11 +4056,15 @@ "node": ">=4" } }, + "node_modules/any-promise": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", + "integrity": "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==" + }, "node_modules/anymatch": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", - "dev": true, "dependencies": { "normalize-path": "^3.0.0", "picomatch": "^2.0.4" @@ -4726,7 +4077,6 @@ "version": "2.3.1", "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "dev": true, "engines": { "node": ">=8.6" }, @@ -4734,6 +4084,11 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, + "node_modules/arg": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/arg/-/arg-5.0.2.tgz", + "integrity": "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==" + }, "node_modules/argparse": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", @@ -4750,7 +4105,6 @@ "version": "10.4.19", "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.19.tgz", "integrity": "sha512-BaENR2+zBZ8xXhM4pUaKUxlVdxZ0EZhjvbopwnXmxRUfqDmwSpC2lAi/QXvx7NRdPCo1WKEcEF6mV64si1z4Ew==", - "dev": true, "funding": [ { "type": "opencollective", @@ -4851,8 +4205,7 @@ "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 + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" }, "node_modules/base64-js": { "version": "1.5.1", @@ -4902,7 +4255,6 @@ "version": "2.3.0", "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", - "dev": true, "engines": { "node": ">=8" }, @@ -4990,7 +4342,6 @@ "version": "3.0.3", "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", - "dev": true, "dependencies": { "fill-range": "^7.1.1" }, @@ -5002,7 +4353,6 @@ "version": "4.23.2", "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.2.tgz", "integrity": "sha512-qkqSyistMYdxAcw+CzbZwlBy8AGmS/eEWs+sEV5TnLRGDOL+C5M2EnH6tlZyg0YoAxGJAFKh61En9BR941GnHA==", - "dev": true, "funding": [ { "type": "opencollective", @@ -5185,11 +4535,18 @@ "node": ">=6" } }, + "node_modules/camelcase-css": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", + "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==", + "engines": { + "node": ">= 6" + } + }, "node_modules/caniuse-lite": { "version": "1.0.30001642", "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001642.tgz", "integrity": "sha512-3XQ0DoRgLijXJErLSl+bLnJ+Et4KqV1PY6JJBGAFlsNsz31zeAIncyeZfLCabHK/jtSh+671RM9YMldxjUPZtA==", - "dev": true, "funding": [ { "type": "opencollective", @@ -5229,7 +4586,6 @@ "version": "3.6.0", "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", - "dev": true, "dependencies": { "anymatch": "~3.1.2", "braces": "~3.0.2", @@ -5819,7 +5175,6 @@ "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", @@ -5833,7 +5188,6 @@ "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" }, @@ -5911,7 +5265,6 @@ "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" }, @@ -6072,6 +5425,16 @@ "integrity": "sha512-uJaamHkagcZtHPqCIHZxnFrXlunQXgBOsZSUOWwFw31QJCAbyTBoHMW75YOTur5ZNx8pIeAKgf6GWIgaqqiLhA==", "dev": true }, + "node_modules/didyoumean": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/didyoumean/-/didyoumean-1.2.2.tgz", + "integrity": "sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==" + }, + "node_modules/dlv": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", + "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==" + }, "node_modules/dns-packet": { "version": "5.6.1", "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-5.6.1.tgz", @@ -6154,8 +5517,7 @@ "node_modules/eastasianwidth": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", - "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", - "dev": true + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==" }, "node_modules/ee-first": { "version": "1.1.1", @@ -6166,8 +5528,7 @@ "node_modules/electron-to-chromium": { "version": "1.4.827", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.827.tgz", - "integrity": "sha512-VY+J0e4SFcNfQy19MEoMdaIcZLmDCprqvBtkii1WTCTQHpRvf5N8+3kTYCgL/PcntvwQvmMJWTuDPsq+IlhWKQ==", - "dev": true + "integrity": "sha512-VY+J0e4SFcNfQy19MEoMdaIcZLmDCprqvBtkii1WTCTQHpRvf5N8+3kTYCgL/PcntvwQvmMJWTuDPsq+IlhWKQ==" }, "node_modules/emoji-regex": { "version": "10.3.0", @@ -6401,7 +5762,6 @@ "version": "3.1.2", "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", - "dev": true, "engines": { "node": ">=6" } @@ -6655,7 +6015,6 @@ "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", @@ -6677,7 +6036,6 @@ "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" } @@ -6698,7 +6056,6 @@ "version": "7.1.1", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", - "dev": true, "dependencies": { "to-regex-range": "^5.0.1" }, @@ -6822,7 +6179,6 @@ "version": "3.2.1", "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.2.1.tgz", "integrity": "sha512-PXUUyLqrR2XCWICfv6ukppP96sdFwWbNEnfEMt7jNsISjMsvaLNinAHNDYyvkyU+SZG2BTSbT5NjG+vZslfGTA==", - "dev": true, "dependencies": { "cross-spawn": "^7.0.0", "signal-exit": "^4.0.1" @@ -6847,7 +6203,6 @@ "version": "4.3.7", "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", - "dev": true, "engines": { "node": "*" }, @@ -6901,7 +6256,6 @@ "version": "2.3.3", "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", - "dev": true, "hasInstallScript": true, "optional": true, "os": [ @@ -6915,7 +6269,6 @@ "version": "1.1.2", "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", - "dev": true, "funding": { "url": "https://github.com/sponsors/ljharb" } @@ -7006,7 +6359,6 @@ "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" }, @@ -7122,7 +6474,6 @@ "version": "2.0.2", "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", - "dev": true, "dependencies": { "function-bind": "^1.1.2" }, @@ -7549,7 +6900,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", - "dev": true, "dependencies": { "binary-extensions": "^2.0.0" }, @@ -7561,7 +6911,6 @@ "version": "2.14.0", "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.14.0.tgz", "integrity": "sha512-a5dFJih5ZLYlRtDc0dZWP7RiKr6xIKzmn/oAYCDvdLThadVgyJwlaoQPmRtMSpz+rk0OGAgIu+TcM9HUF0fk1A==", - "dev": true, "dependencies": { "hasown": "^2.0.2" }, @@ -7591,7 +6940,6 @@ "version": "2.1.1", "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", - "dev": true, "engines": { "node": ">=0.10.0" } @@ -7612,7 +6960,6 @@ "version": "4.0.3", "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, "dependencies": { "is-extglob": "^2.1.1" }, @@ -7669,7 +7016,6 @@ "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "dev": true, "engines": { "node": ">=0.12.0" } @@ -7764,8 +7110,7 @@ "node_modules/isexe": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", - "dev": true + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" }, "node_modules/isobject": { "version": "3.0.1", @@ -7876,7 +7221,6 @@ "version": "3.4.3", "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz", "integrity": "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==", - "dev": true, "dependencies": { "@isaacs/cliui": "^8.0.2" }, @@ -7935,7 +7279,6 @@ "version": "1.21.6", "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.6.tgz", "integrity": "sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==", - "dev": true, "bin": { "jiti": "bin/jiti.js" } @@ -8427,11 +7770,18 @@ } } }, + "node_modules/lilconfig": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz", + "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==", + "engines": { + "node": ">=10" + } + }, "node_modules/lines-and-columns": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", - "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", - "dev": true + "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" }, "node_modules/listr2": { "version": "8.2.3", @@ -8902,7 +8252,6 @@ "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" } @@ -8920,7 +8269,6 @@ "version": "4.0.7", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", - "dev": true, "dependencies": { "braces": "^3.0.3", "picomatch": "^2.3.1" @@ -8933,7 +8281,6 @@ "version": "2.3.1", "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "dev": true, "engines": { "node": ">=8.6" }, @@ -9034,7 +8381,6 @@ "version": "7.1.2", "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", - "dev": true, "engines": { "node": ">=16 || 14 >=14.17" } @@ -9269,11 +8615,20 @@ "node": "^14.17.0 || ^16.13.0 || >=18.0.0" } }, + "node_modules/mz": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", + "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", + "dependencies": { + "any-promise": "^1.0.0", + "object-assign": "^4.0.1", + "thenify-all": "^1.0.0" + } + }, "node_modules/nanoid": { "version": "3.3.7", "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", - "dev": true, "funding": [ { "type": "github", @@ -9490,8 +8845,7 @@ "node_modules/node-releases": { "version": "2.0.14", "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", - "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", - "dev": true + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==" }, "node_modules/nopt": { "version": "7.2.1", @@ -9526,7 +8880,6 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true, "engines": { "node": ">=0.10.0" } @@ -9535,7 +8888,6 @@ "version": "0.1.2", "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", - "dev": true, "engines": { "node": ">=0.10.0" } @@ -9662,11 +9014,18 @@ "version": "4.1.1", "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", - "dev": true, "engines": { "node": ">=0.10.0" } }, + "node_modules/object-hash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", + "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", + "engines": { + "node": ">= 6" + } + }, "node_modules/object-inspect": { "version": "1.13.2", "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", @@ -9961,8 +9320,7 @@ "node_modules/package-json-from-dist": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.0.tgz", - "integrity": "sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==", - "dev": true + "integrity": "sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==" }, "node_modules/pacote": { "version": "18.0.6", @@ -10109,7 +9467,6 @@ "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" } @@ -10117,14 +9474,12 @@ "node_modules/path-parse": { "version": "1.0.7", "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", - "dev": true + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" }, "node_modules/path-scurry": { "version": "1.11.1", "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", - "dev": true, "dependencies": { "lru-cache": "^10.2.0", "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" @@ -10139,8 +9494,7 @@ "node_modules/path-scurry/node_modules/lru-cache": { "version": "10.4.3", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", - "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", - "dev": true + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==" }, "node_modules/path-to-regexp": { "version": "0.1.7", @@ -10163,8 +9517,7 @@ "node_modules/picocolors": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", - "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", - "dev": true + "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==" }, "node_modules/picomatch": { "version": "4.0.2", @@ -10188,6 +9541,14 @@ "node": ">=6" } }, + "node_modules/pirates": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", + "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", + "engines": { + "node": ">= 6" + } + }, "node_modules/piscina": { "version": "4.6.1", "resolved": "https://registry.npmjs.org/piscina/-/piscina-4.6.1.tgz", @@ -10213,10 +9574,9 @@ } }, "node_modules/postcss": { - "version": "8.4.38", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", - "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", - "dev": true, + "version": "8.4.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.39.tgz", + "integrity": "sha512-0vzE+lAiG7hZl1/9I8yzKLx3aR9Xbof3fBHKunvMfOCYAtMhrsnccJY2iTURb9EZd5+pLuiNV9/c/GZJOHsgIw==", "funding": [ { "type": "opencollective", @@ -10233,13 +9593,92 @@ ], "dependencies": { "nanoid": "^3.3.7", - "picocolors": "^1.0.0", + "picocolors": "^1.0.1", "source-map-js": "^1.2.0" }, "engines": { "node": "^10 || ^12 || >=14" } }, + "node_modules/postcss-import": { + "version": "15.1.0", + "resolved": "https://registry.npmjs.org/postcss-import/-/postcss-import-15.1.0.tgz", + "integrity": "sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==", + "dependencies": { + "postcss-value-parser": "^4.0.0", + "read-cache": "^1.0.0", + "resolve": "^1.1.7" + }, + "engines": { + "node": ">=14.0.0" + }, + "peerDependencies": { + "postcss": "^8.0.0" + } + }, + "node_modules/postcss-js": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-js/-/postcss-js-4.0.1.tgz", + "integrity": "sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==", + "dependencies": { + "camelcase-css": "^2.0.1" + }, + "engines": { + "node": "^12 || ^14 || >= 16" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.4.21" + } + }, + "node_modules/postcss-load-config": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-4.0.2.tgz", + "integrity": "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "lilconfig": "^3.0.0", + "yaml": "^2.3.4" + }, + "engines": { + "node": ">= 14" + }, + "peerDependencies": { + "postcss": ">=8.0.9", + "ts-node": ">=9.0.0" + }, + "peerDependenciesMeta": { + "postcss": { + "optional": true + }, + "ts-node": { + "optional": true + } + } + }, + "node_modules/postcss-load-config/node_modules/lilconfig": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.2.tgz", + "integrity": "sha512-eop+wDAvpItUys0FWkHIKeC9ybYrTGbU41U5K7+bttZZeohvnY7M9dZ5kB21GNWiFT2q1OoPTvncPCgSOVO5ow==", + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/antonk52" + } + }, "node_modules/postcss-loader": { "version": "8.1.1", "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-8.1.1.tgz", @@ -10336,11 +9775,28 @@ "postcss": "^8.1.0" } }, + "node_modules/postcss-nested": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/postcss-nested/-/postcss-nested-6.0.1.tgz", + "integrity": "sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ==", + "dependencies": { + "postcss-selector-parser": "^6.0.11" + }, + "engines": { + "node": ">=12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.2.14" + } + }, "node_modules/postcss-selector-parser": { "version": "6.1.1", "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.1.1.tgz", "integrity": "sha512-b4dlw/9V8A71rLIDsSwVmak9z2DuBUB7CA1/wSdelNEzqsjoSPeADTWNO09lpH49Diy3/JIZ2bSPB1dI3LJCHg==", - "dev": true, "dependencies": { "cssesc": "^3.0.0", "util-deprecate": "^1.0.2" @@ -10352,8 +9808,7 @@ "node_modules/postcss-value-parser": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", - "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", - "dev": true + "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==" }, "node_modules/proc-log": { "version": "4.2.0", @@ -10452,7 +9907,6 @@ "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", @@ -10501,6 +9955,22 @@ "node": ">= 0.8" } }, + "node_modules/read-cache": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", + "integrity": "sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==", + "dependencies": { + "pify": "^2.3.0" + } + }, + "node_modules/read-cache/node_modules/pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/readable-stream": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", @@ -10519,7 +9989,6 @@ "version": "3.6.0", "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dev": true, "dependencies": { "picomatch": "^2.2.1" }, @@ -10531,7 +10000,6 @@ "version": "2.3.1", "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "dev": true, "engines": { "node": ">=8.6" }, @@ -10650,7 +10118,6 @@ "version": "1.22.8", "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", - "dev": true, "dependencies": { "is-core-module": "^2.13.0", "path-parse": "^1.0.7", @@ -10746,7 +10213,6 @@ "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" @@ -10825,7 +10291,6 @@ "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", @@ -11207,7 +10672,6 @@ "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" }, @@ -11219,7 +10683,6 @@ "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" } @@ -11255,7 +10718,6 @@ "version": "4.1.0", "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", - "dev": true, "engines": { "node": ">=14" }, @@ -11423,7 +10885,6 @@ "version": "1.2.0", "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", - "dev": true, "engines": { "node": ">=0.10.0" } @@ -11613,7 +11074,6 @@ "version": "4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, "dependencies": { "emoji-regex": "^8.0.0", "is-fullwidth-code-point": "^3.0.0", @@ -11626,14 +11086,12 @@ "node_modules/string-width-cjs/node_modules/emoji-regex": { "version": "8.0.0", "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" }, "node_modules/string-width-cjs/node_modules/is-fullwidth-code-point": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true, "engines": { "node": ">=8" } @@ -11669,7 +11127,6 @@ "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" }, @@ -11682,7 +11139,6 @@ "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" }, @@ -11699,6 +11155,76 @@ "node": ">=6" } }, + "node_modules/sucrase": { + "version": "3.35.0", + "resolved": "https://registry.npmjs.org/sucrase/-/sucrase-3.35.0.tgz", + "integrity": "sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA==", + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.2", + "commander": "^4.0.0", + "glob": "^10.3.10", + "lines-and-columns": "^1.1.6", + "mz": "^2.7.0", + "pirates": "^4.0.1", + "ts-interface-checker": "^0.1.9" + }, + "bin": { + "sucrase": "bin/sucrase", + "sucrase-node": "bin/sucrase-node" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, + "node_modules/sucrase/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/sucrase/node_modules/commander": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", + "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", + "engines": { + "node": ">= 6" + } + }, + "node_modules/sucrase/node_modules/glob": { + "version": "10.4.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", + "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^3.1.2", + "minimatch": "^9.0.4", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^1.11.1" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/sucrase/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, "node_modules/supports-color": { "version": "5.5.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", @@ -11715,7 +11241,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "dev": true, "engines": { "node": ">= 0.4" }, @@ -11732,6 +11257,53 @@ "node": ">=0.10" } }, + "node_modules/tailwindcss": { + "version": "3.4.4", + "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.4.tgz", + "integrity": "sha512-ZoyXOdJjISB7/BcLTR6SEsLgKtDStYyYZVLsUtWChO4Ps20CBad7lfJKVDiejocV4ME1hLmyY0WJE3hSDcmQ2A==", + "dependencies": { + "@alloc/quick-lru": "^5.2.0", + "arg": "^5.0.2", + "chokidar": "^3.5.3", + "didyoumean": "^1.2.2", + "dlv": "^1.1.3", + "fast-glob": "^3.3.0", + "glob-parent": "^6.0.2", + "is-glob": "^4.0.3", + "jiti": "^1.21.0", + "lilconfig": "^2.1.0", + "micromatch": "^4.0.5", + "normalize-path": "^3.0.0", + "object-hash": "^3.0.0", + "picocolors": "^1.0.0", + "postcss": "^8.4.23", + "postcss-import": "^15.1.0", + "postcss-js": "^4.0.1", + "postcss-load-config": "^4.0.1", + "postcss-nested": "^6.0.1", + "postcss-selector-parser": "^6.0.11", + "resolve": "^1.22.2", + "sucrase": "^3.32.0" + }, + "bin": { + "tailwind": "lib/cli.js", + "tailwindcss": "lib/cli.js" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/tailwindcss/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==", + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, "node_modules/tapable": { "version": "2.2.1", "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", @@ -11910,6 +11482,25 @@ "url": "https://opencollective.com/webpack" } }, + "node_modules/thenify": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", + "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", + "dependencies": { + "any-promise": "^1.0.0" + } + }, + "node_modules/thenify-all": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", + "integrity": "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==", + "dependencies": { + "thenify": ">= 3.1.0 < 4" + }, + "engines": { + "node": ">=0.8" + } + }, "node_modules/thingies": { "version": "1.21.0", "resolved": "https://registry.npmjs.org/thingies/-/thingies-1.21.0.tgz", @@ -11953,7 +11544,6 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dev": true, "dependencies": { "is-number": "^7.0.0" }, @@ -11995,6 +11585,11 @@ "tree-kill": "cli.js" } }, + "node_modules/ts-interface-checker": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz", + "integrity": "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==" + }, "node_modules/tslib": { "version": "2.6.3", "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", @@ -12194,7 +11789,6 @@ "version": "1.1.0", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.0.tgz", "integrity": "sha512-EdRAaAyk2cUE1wOf2DkEhzxqOQvFOoRJFNS6NeyJ01Gp2beMRpBAINjM2iDXE3KCuKhwnvHIQCJm6ThL2Z+HzQ==", - "dev": true, "funding": [ { "type": "opencollective", @@ -12241,8 +11835,7 @@ "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 + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" }, "node_modules/utils-merge": { "version": "1.0.1", @@ -12771,7 +12364,6 @@ "version": "7.0.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, "dependencies": { "ansi-styles": "^4.0.0", "string-width": "^4.1.0", @@ -12788,7 +12380,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -12803,7 +12394,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -12814,20 +12404,17 @@ "node_modules/wrap-ansi-cjs/node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { "version": "8.0.0", "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" }, "node_modules/wrap-ansi-cjs/node_modules/is-fullwidth-code-point": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true, "engines": { "node": ">=8" } @@ -12836,7 +12423,6 @@ "version": "4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, "dependencies": { "emoji-regex": "^8.0.0", "is-fullwidth-code-point": "^3.0.0", @@ -12950,6 +12536,17 @@ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", "dev": true }, + "node_modules/yaml": { + "version": "2.4.5", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.4.5.tgz", + "integrity": "sha512-aBx2bnqDzVOyNKfsysjA2ms5ZlnjSAW2eG3/L5G/CSujfjLJTJsEw1bGw8kCf04KodQWk1pxlGnZ56CRxiawmg==", + "bin": { + "yaml": "bin.mjs" + }, + "engines": { + "node": ">= 14" + } + }, "node_modules/yargs": { "version": "17.7.2", "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", diff --git a/webapp/package.json b/webapp/package.json index 7154c9c7..14800cc4 100644 --- a/webapp/package.json +++ b/webapp/package.json @@ -10,29 +10,31 @@ }, "private": true, "dependencies": { - "@angular/animations": "^18.1.0", - "@angular/common": "^18.1.0", - "@angular/compiler": "^18.1.0", - "@angular/core": "^18.1.0", - "@angular/forms": "^18.1.0", - "@angular/platform-browser": "^18.1.0", - "@angular/platform-browser-dynamic": "^18.1.0", - "@angular/router": "^18.1.0", - "rxjs": "~7.8.0", - "tslib": "^2.3.0", - "zone.js": "~0.14.3" + "@angular/animations": "18.1.0", + "@angular/common": "18.1.0", + "@angular/compiler": "18.1.0", + "@angular/core": "18.1.0", + "@angular/forms": "18.1.0", + "@angular/platform-browser": "18.1.0", + "@angular/platform-browser-dynamic": "18.1.0", + "@angular/router": "18.1.0", + "autoprefixer": "10.4.19", + "postcss": "8.4.39", + "rxjs": "7.8.1", + "tailwindcss": "3.4.4", + "tslib": "2.6.3" }, "devDependencies": { - "@angular-devkit/build-angular": "^18.1.0", - "@angular/cli": "^18.1.0", - "@angular/compiler-cli": "^18.1.0", - "@types/jasmine": "~5.1.0", - "jasmine-core": "~5.1.0", - "karma": "~6.4.0", - "karma-chrome-launcher": "~3.2.0", - "karma-coverage": "~2.2.0", - "karma-jasmine": "~5.1.0", - "karma-jasmine-html-reporter": "~2.1.0", - "typescript": "~5.5.2" + "@angular-devkit/build-angular": "18.1.0", + "@angular/cli": "18.1.0", + "@angular/compiler-cli": "18.1.0", + "@types/jasmine": "5.1.4", + "jasmine-core": "5.1.2", + "karma": "6.4.3", + "karma-chrome-launcher": "3.2.0", + "karma-coverage": "2.2.1", + "karma-jasmine": "5.1.0", + "karma-jasmine-html-reporter": "2.1.0", + "typescript": "5.5.3" } } diff --git a/webapp/postcss.config.js b/webapp/postcss.config.js new file mode 100644 index 00000000..c3188862 --- /dev/null +++ b/webapp/postcss.config.js @@ -0,0 +1,6 @@ +module.exports = { + plugins: [ + require('tailwindcss'), + require('autoprefixer'), + ], +}; \ No newline at end of file diff --git a/webapp/src/app/hello-world/hello-world.component.html b/webapp/src/app/hello-world/hello-world.component.html index 589144d4..b6707154 100644 --- a/webapp/src/app/hello-world/hello-world.component.html +++ b/webapp/src/app/hello-world/hello-world.component.html @@ -1 +1 @@ -

hello-world works!

+

hello-world works!

diff --git a/webapp/src/styles.css b/webapp/src/styles.css new file mode 100644 index 00000000..bd6213e1 --- /dev/null +++ b/webapp/src/styles.css @@ -0,0 +1,3 @@ +@tailwind base; +@tailwind components; +@tailwind utilities; \ No newline at end of file diff --git a/webapp/src/styles.sass b/webapp/src/styles.sass deleted file mode 100644 index 90d4ee00..00000000 --- a/webapp/src/styles.sass +++ /dev/null @@ -1 +0,0 @@ -/* You can add global styles to this file, and also import other style files */ diff --git a/webapp/tailwind.config.js b/webapp/tailwind.config.js new file mode 100644 index 00000000..eeced4e2 --- /dev/null +++ b/webapp/tailwind.config.js @@ -0,0 +1,9 @@ +/** @type {import('tailwindcss').Config} */ +module.exports = { + content: ['./src/**/*.{html,ts}'], + theme: { + extend: {}, + }, + plugins: [], +} + From 9a5e67cdd8a9a6b8becae0d66c44f131d4820017 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Sun, 14 Jul 2024 19:03:20 +0200 Subject: [PATCH 04/12] remove placeholder content --- webapp/src/app/app.component.html | 344 +----------------------------- webapp/src/app/app.component.ts | 2 +- webapp/src/index.html | 2 +- 3 files changed, 9 insertions(+), 339 deletions(-) diff --git a/webapp/src/app/app.component.html b/webapp/src/app/app.component.html index 98744693..fbd3fbea 100644 --- a/webapp/src/app/app.component.html +++ b/webapp/src/app/app.component.html @@ -1,337 +1,7 @@ - - - - - - - - - - - -
-
-
- -

Hello, {{ title }}

-

Congratulations! Your app is running. 🎉

-
- -
-
- @for (item of [ - { title: 'Explore the Docs', link: 'https://angular.dev' }, - { title: 'Learn with Tutorials', link: 'https://angular.dev/tutorials' }, - { title: 'CLI Docs', link: 'https://angular.dev/tools/cli' }, - { title: 'Angular Language Service', link: 'https://angular.dev/tools/language-service' }, - { title: 'Angular DevTools', link: 'https://angular.dev/tools/devtools' }, - ]; track item.title) { - - {{ item.title }} - - - - - } -
- -
-
-
- - - - - - - - - - - - +
+
+

Header

+
+ + +
\ No newline at end of file diff --git a/webapp/src/app/app.component.ts b/webapp/src/app/app.component.ts index a21954e4..a99e9987 100644 --- a/webapp/src/app/app.component.ts +++ b/webapp/src/app/app.component.ts @@ -10,5 +10,5 @@ import { HelloWorldComponent } from './hello-world/hello-world.component'; styles: [], }) export class AppComponent { - title = 'webapp'; + title = 'Hephaestus'; } diff --git a/webapp/src/index.html b/webapp/src/index.html index 5b75346d..c4c981e0 100644 --- a/webapp/src/index.html +++ b/webapp/src/index.html @@ -2,7 +2,7 @@ - Webapp + Hephaestus From bb592dfca19eea03393f8b1d62fca7030f8dc536 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Sun, 14 Jul 2024 20:19:26 +0200 Subject: [PATCH 05/12] add poke openapi specs --- server/openapi.yml | 9385 ++++++++++++++++++++++++++++++++++ webapp/src/app/app.config.ts | 1 - 2 files changed, 9385 insertions(+), 1 deletion(-) create mode 100644 server/openapi.yml diff --git a/server/openapi.yml b/server/openapi.yml new file mode 100644 index 00000000..5e45840d --- /dev/null +++ b/server/openapi.yml @@ -0,0 +1,9385 @@ +openapi: 3.1.0 +info: + title: PokéAPI + version: 2.7.0 + description: "All the Pokémon data you'll ever need in one place, easily accessible\ + \ through a modern free open-source RESTful API.\n\n## What is this?\n\nThis is\ + \ a full RESTful API linked to an extensive database detailing everything about\ + \ the Pokémon main game series.\n\nWe've covered everything from Pokémon to Berry\ + \ Flavors.\n\n## Where do I start?\n\nWe have awesome [documentation](https://pokeapi.co/docs/v2)\ + \ on how to use this API. It takes minutes to get started.\n\nThis API will always\ + \ be publicly available and will never require any extensive setup process to\ + \ consume.\n\nCreated by [**Paul Hallett**(]https://github.com/phalt) and other\ + \ [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing)\ + \ around the world. Pokémon and Pokémon character names are trademarks of Nintendo.\n\ + \ " +paths: + /api/v2/ability/: + get: + operationId: ability_list + description: Abilities provide passive effects for Pokémon in battle or in the + overworld. Pokémon have multiple possible abilities but can have only one + ability at a time. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Ability) + for greater detail. + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedAbilitySummaryList' + description: '' + /api/v2/ability/{id}/: + get: + operationId: ability_retrieve + description: Abilities provide passive effects for Pokémon in battle or in the + overworld. Pokémon have multiple possible abilities but can have only one + ability at a time. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Ability) + for greater detail. + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/AbilityDetail' + description: '' + /api/v2/berry/: + get: + operationId: berry_list + description: Berries are small fruits that can provide HP and status condition + restoration, stat enhancement, and even damage negation when eaten by Pokémon. + Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Berry) for greater + detail. + summary: List berries + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - berries + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedBerrySummaryList' + description: '' + /api/v2/berry/{id}/: + get: + operationId: berry_retrieve + description: Berries are small fruits that can provide HP and status condition + restoration, stat enhancement, and even damage negation when eaten by Pokémon. + Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Berry) for greater + detail. + summary: Get a berry + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - berries + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/BerryDetail' + description: '' + /api/v2/berry-firmness/: + get: + operationId: berry_firmness_list + description: Berries can be soft or hard. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Category:Berries_by_firmness) + for greater detail. + summary: List berry firmness + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - berries + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedBerryFirmnessSummaryList' + description: '' + /api/v2/berry-firmness/{id}/: + get: + operationId: berry_firmness_retrieve + description: Berries can be soft or hard. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Category:Berries_by_firmness) + for greater detail. + summary: Get berry by firmness + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - berries + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/BerryFirmnessDetail' + description: '' + /api/v2/berry-flavor/: + get: + operationId: berry_flavor_list + description: Flavors determine whether a Pokémon will benefit or suffer from + eating a berry based on their **nature**. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Flavor) + for greater detail. + summary: List berry flavors + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - berries + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedBerryFlavorSummaryList' + description: '' + /api/v2/berry-flavor/{id}/: + get: + operationId: berry_flavor_retrieve + description: Flavors determine whether a Pokémon will benefit or suffer from + eating a berry based on their **nature**. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Flavor) + for greater detail. + summary: Get berries by flavor + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - berries + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/BerryFlavorDetail' + description: '' + /api/v2/characteristic/: + get: + operationId: characteristic_list + description: Characteristics indicate which stat contains a Pokémon's highest + IV. A Pokémon's Characteristic is determined by the remainder of its highest + IV divided by 5 (gene_modulo). Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Characteristic) + for greater detail. + summary: List charecterictics + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedCharacteristicSummaryList' + description: '' + /api/v2/characteristic/{id}/: + get: + operationId: characteristic_retrieve + description: Characteristics indicate which stat contains a Pokémon's highest + IV. A Pokémon's Characteristic is determined by the remainder of its highest + IV divided by 5 (gene_modulo). Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Characteristic) + for greater detail. + summary: Get characteristic + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/CharacteristicDetail' + description: '' + /api/v2/contest-type/: + get: + operationId: contest_type_list + description: Contest types are categories judges used to weigh a Pokémon's condition + in Pokémon contests. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Contest_condition) + for greater detail. + summary: List contest types + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - contests + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedContestTypeSummaryList' + description: '' + /api/v2/contest-type/{id}/: + get: + operationId: contest_type_retrieve + description: Contest types are categories judges used to weigh a Pokémon's condition + in Pokémon contests. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Contest_condition) + for greater detail. + summary: Get contest type + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - contests + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/ContestTypeDetail' + description: '' + /api/v2/contest-effect/: + get: + operationId: contest_effect_list + description: Contest effects refer to the effects of moves when used in contests. + summary: List contest effects + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - contests + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedContestEffectSummaryList' + description: '' + /api/v2/contest-effect/{id}/: + get: + operationId: contest_effect_retrieve + description: Contest effects refer to the effects of moves when used in contests. + summary: Get contest effect + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - contests + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/ContestEffectDetail' + description: '' + /api/v2/egg-group/: + get: + operationId: egg_group_list + description: Egg Groups are categories which determine which Pokémon are able + to interbreed. Pokémon may belong to either one or two Egg Groups. Check out + [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Egg_Group) for greater + detail. + summary: List egg groups + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedEggGroupSummaryList' + description: '' + /api/v2/egg-group/{id}/: + get: + operationId: egg_group_retrieve + description: Egg Groups are categories which determine which Pokémon are able + to interbreed. Pokémon may belong to either one or two Egg Groups. Check out + [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Egg_Group) for greater + detail. + summary: Get egg group + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/EggGroupDetail' + description: '' + /api/v2/encounter-method/: + get: + operationId: encounter_method_list + description: Methods by which the player might can encounter Pokémon in the + wild, e.g., walking in tall grass. Check out Bulbapedia for greater detail. + summary: List encounter methods + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - encounters + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedEncounterMethodSummaryList' + description: '' + /api/v2/encounter-method/{id}/: + get: + operationId: encounter_method_retrieve + description: Methods by which the player might can encounter Pokémon in the + wild, e.g., walking in tall grass. Check out Bulbapedia for greater detail. + summary: Get encounter method + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - encounters + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/EncounterMethodDetail' + description: '' + /api/v2/encounter-condition/: + get: + operationId: encounter_condition_list + description: Conditions which affect what pokemon might appear in the wild, + e.g., day or night. + summary: List encounter conditions + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - encounters + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedEncounterConditionSummaryList' + description: '' + /api/v2/encounter-condition/{id}/: + get: + operationId: encounter_condition_retrieve + description: Conditions which affect what pokemon might appear in the wild, + e.g., day or night. + summary: Get encounter condition + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - encounters + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/EncounterConditionDetail' + description: '' + /api/v2/encounter-condition-value/: + get: + operationId: encounter_condition_value_list + description: Encounter condition values are the various states that an encounter + condition can have, i.e., time of day can be either day or night. + summary: List encounter condition values + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - encounters + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedEncounterConditionValueSummaryList' + description: '' + /api/v2/encounter-condition-value/{id}/: + get: + operationId: encounter_condition_value_retrieve + description: Encounter condition values are the various states that an encounter + condition can have, i.e., time of day can be either day or night. + summary: Get encounter condition value + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - encounters + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/EncounterConditionValueDetail' + description: '' + /api/v2/evolution-chain/: + get: + operationId: evolution_chain_list + description: Evolution chains are essentially family trees. They start with + the lowest stage within a family and detail evolution conditions for each + as well as Pokémon they can evolve into up through the hierarchy. + summary: List evolution chains + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - evolution + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedEvolutionChainSummaryList' + description: '' + /api/v2/evolution-chain/{id}/: + get: + operationId: evolution_chain_retrieve + description: Evolution chains are essentially family trees. They start with + the lowest stage within a family and detail evolution conditions for each + as well as Pokémon they can evolve into up through the hierarchy. + summary: Get evolution chain + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - evolution + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/EvolutionChainDetail' + description: '' + /api/v2/evolution-trigger/: + get: + operationId: evolution_trigger_list + description: Evolution triggers are the events and conditions that cause a Pokémon + to evolve. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Methods_of_evolution) + for greater detail. + summary: List evolution triggers + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - evolution + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedEvolutionTriggerSummaryList' + description: '' + /api/v2/evolution-trigger/{id}/: + get: + operationId: evolution_trigger_retrieve + description: Evolution triggers are the events and conditions that cause a Pokémon + to evolve. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Methods_of_evolution) + for greater detail. + summary: Get evolution trigger + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - evolution + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/EvolutionTriggerDetail' + description: '' + /api/v2/generation/: + get: + operationId: generation_list + description: A generation is a grouping of the Pokémon games that separates + them based on the Pokémon they include. In each generation, a new set of Pokémon, + Moves, Abilities and Types that did not exist in the previous generation are + released. + summary: List genrations + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedGenerationSummaryList' + description: '' + /api/v2/generation/{id}/: + get: + operationId: generation_retrieve + description: A generation is a grouping of the Pokémon games that separates + them based on the Pokémon they include. In each generation, a new set of Pokémon, + Moves, Abilities and Types that did not exist in the previous generation are + released. + summary: Get genration + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/GenerationDetail' + description: '' + /api/v2/gender/: + get: + operationId: gender_list + description: Genders were introduced in Generation II for the purposes of breeding + Pokémon but can also result in visual differences or even different evolutionary + lines. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Gender) + for greater detail. + summary: List genders + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedGenderSummaryList' + description: '' + /api/v2/gender/{id}/: + get: + operationId: gender_retrieve + description: Genders were introduced in Generation II for the purposes of breeding + Pokémon but can also result in visual differences or even different evolutionary + lines. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Gender) + for greater detail. + summary: Get gender + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/GenderDetail' + description: '' + /api/v2/growth-rate/: + get: + operationId: growth_rate_list + description: Growth rates are the speed with which Pokémon gain levels through + experience. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Experience) + for greater detail. + summary: List growth rates + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedGrowthRateSummaryList' + description: '' + /api/v2/growth-rate/{id}/: + get: + operationId: growth_rate_retrieve + description: Growth rates are the speed with which Pokémon gain levels through + experience. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Experience) + for greater detail. + summary: Get growth rate + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/GrowthRateDetail' + description: '' + /api/v2/item/: + get: + operationId: item_list + description: An item is an object in the games which the player can pick up, + keep in their bag, and use in some manner. They have various uses, including + healing, powering up, helping catch Pokémon, or to access a new area. + summary: List items + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedItemSummaryList' + description: '' + /api/v2/item/{id}/: + get: + operationId: item_retrieve + description: An item is an object in the games which the player can pick up, + keep in their bag, and use in some manner. They have various uses, including + healing, powering up, helping catch Pokémon, or to access a new area. + summary: Get item + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/ItemDetail' + description: '' + /api/v2/item-category/: + get: + operationId: item_category_list + description: Item categories determine where items will be placed in the players + bag. + summary: List item categories + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedItemCategorySummaryList' + description: '' + /api/v2/item-category/{id}/: + get: + operationId: item_category_retrieve + description: Item categories determine where items will be placed in the players + bag. + summary: Get item category + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/ItemCategoryDetail' + description: '' + /api/v2/item-attribute/: + get: + operationId: item_attribute_list + description: Item attributes define particular aspects of items, e.g."usable + in battle" or "consumable". + summary: List item attributes + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedItemAttributeSummaryList' + description: '' + /api/v2/item-attribute/{id}/: + get: + operationId: item_attribute_retrieve + description: Item attributes define particular aspects of items, e.g."usable + in battle" or "consumable". + summary: Get item attribute + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/ItemAttributeDetail' + description: '' + /api/v2/item-fling-effect/: + get: + operationId: item_fling_effect_list + description: The various effects of the move"Fling" when used with different + items. + summary: List item fling effects + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedItemFlingEffectSummaryList' + description: '' + /api/v2/item-fling-effect/{id}/: + get: + operationId: item_fling_effect_retrieve + description: The various effects of the move"Fling" when used with different + items. + summary: Get item fling effect + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/ItemFlingEffectDetail' + description: '' + /api/v2/item-pocket/: + get: + operationId: item_pocket_list + description: Pockets within the players bag used for storing items by category. + summary: List item pockets + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedItemPocketSummaryList' + description: '' + /api/v2/item-pocket/{id}/: + get: + operationId: item_pocket_retrieve + description: Pockets within the players bag used for storing items by category. + summary: Get item pocket + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - items + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/ItemPocketDetail' + description: '' + /api/v2/language/: + get: + operationId: language_list + description: Languages for translations of API resource information. + summary: List languages + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - utility + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedLanguageSummaryList' + description: '' + /api/v2/language/{id}/: + get: + operationId: language_retrieve + description: Languages for translations of API resource information. + summary: Get language + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - utility + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/LanguageDetail' + description: '' + /api/v2/location/: + get: + operationId: location_list + description: Locations that can be visited within the games. Locations make + up sizable portions of regions, like cities or routes. + summary: List locations + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedLocationSummaryList' + description: '' + /api/v2/location/{id}/: + get: + operationId: location_retrieve + description: Locations that can be visited within the games. Locations make + up sizable portions of regions, like cities or routes. + summary: Get location + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/LocationDetail' + description: '' + /api/v2/location-area/: + get: + operationId: location_area_list + description: Location areas are sections of areas, such as floors in a building + or cave. Each area has its own set of possible Pokémon encounters. + summary: List location areas + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedLocationAreaSummaryList' + description: '' + /api/v2/location-area/{id}/: + get: + operationId: location_area_retrieve + description: Location areas are sections of areas, such as floors in a building + or cave. Each area has its own set of possible Pokémon encounters. + summary: Get location area + parameters: + - in: path + name: id + schema: + type: integer + description: A unique integer value identifying this location area. + required: true + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/LocationAreaDetail' + description: '' + /api/v2/machine/: + get: + operationId: machine_list + description: Machines are the representation of items that teach moves to Pokémon. + They vary from version to version, so it is not certain that one specific + TM or HM corresponds to a single Machine. + summary: List machines + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - machines + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMachineSummaryList' + description: '' + /api/v2/machine/{id}/: + get: + operationId: machine_retrieve + description: Machines are the representation of items that teach moves to Pokémon. + They vary from version to version, so it is not certain that one specific + TM or HM corresponds to a single Machine. + summary: Get machine + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - machines + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MachineDetail' + description: '' + /api/v2/move/: + get: + operationId: move_list + description: Moves are the skills of Pokémon in battle. In battle, a Pokémon + uses one move each turn. Some moves (including those learned by Hidden Machine) + can be used outside of battle as well, usually for the purpose of removing + obstacles or exploring new areas. + summary: List moves + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMoveSummaryList' + description: '' + /api/v2/move/{id}/: + get: + operationId: move_retrieve + description: Moves are the skills of Pokémon in battle. In battle, a Pokémon + uses one move each turn. Some moves (including those learned by Hidden Machine) + can be used outside of battle as well, usually for the purpose of removing + obstacles or exploring new areas. + summary: Get move + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MoveDetail' + description: '' + /api/v2/move-ailment/: + get: + operationId: move_ailment_list + description: Move Ailments are status conditions caused by moves used during + battle. See [Bulbapedia](https://bulbapedia.bulbagarden.net/wiki/Status_condition) + for greater detail. + summary: List move meta ailments + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMoveMetaAilmentSummaryList' + description: '' + /api/v2/move-ailment/{id}/: + get: + operationId: move_ailment_retrieve + description: Move Ailments are status conditions caused by moves used during + battle. See [Bulbapedia](https://bulbapedia.bulbagarden.net/wiki/Status_condition) + for greater detail. + summary: Get move meta ailment + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MoveMetaAilmentDetail' + description: '' + /api/v2/move-battle-style/: + get: + operationId: move_battle_style_list + description: Styles of moves when used in the Battle Palace. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Battle_Frontier_(Generation_III)) + for greater detail. + summary: List move battle styles + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMoveBattleStyleSummaryList' + description: '' + /api/v2/move-battle-style/{id}/: + get: + operationId: move_battle_style_retrieve + description: Styles of moves when used in the Battle Palace. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Battle_Frontier_(Generation_III)) + for greater detail. + summary: Get move battle style + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MoveBattleStyleDetail' + description: '' + /api/v2/move-category/: + get: + operationId: move_category_list + description: Very general categories that loosely group move effects. + summary: List move meta categories + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMoveMetaCategorySummaryList' + description: '' + /api/v2/move-category/{id}/: + get: + operationId: move_category_retrieve + description: Very general categories that loosely group move effects. + summary: Get move meta category + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MoveMetaCategoryDetail' + description: '' + /api/v2/move-damage-class/: + get: + operationId: move_damage_class_list + description: Damage classes moves can have, e.g. physical, special, or non-damaging. + summary: List move damage classes + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMoveDamageClassSummaryList' + description: '' + /api/v2/move-damage-class/{id}/: + get: + operationId: move_damage_class_retrieve + description: Damage classes moves can have, e.g. physical, special, or non-damaging. + summary: Get move damage class + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MoveDamageClassDetail' + description: '' + /api/v2/move-learn-method/: + get: + operationId: move_learn_method_list + description: Methods by which Pokémon can learn moves. + summary: List move learn methods + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMoveLearnMethodSummaryList' + description: '' + /api/v2/move-learn-method/{id}/: + get: + operationId: move_learn_method_retrieve + description: Methods by which Pokémon can learn moves. + summary: Get move learn method + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MoveLearnMethodDetail' + description: '' + /api/v2/move-target/: + get: + operationId: move_target_list + description: Targets moves can be directed at during battle. Targets can be + Pokémon, environments or even other moves. + summary: List move targets + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedMoveTargetSummaryList' + description: '' + /api/v2/move-target/{id}/: + get: + operationId: move_target_retrieve + description: Targets moves can be directed at during battle. Targets can be + Pokémon, environments or even other moves. + summary: Get move target + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - moves + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/MoveTargetDetail' + description: '' + /api/v2/nature/: + get: + operationId: nature_list + description: Natures influence how a Pokémon's stats grow. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Nature) + for greater detail. + summary: List natures + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedNatureSummaryList' + description: '' + /api/v2/nature/{id}/: + get: + operationId: nature_retrieve + description: Natures influence how a Pokémon's stats grow. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Nature) + for greater detail. + summary: Get nature + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/NatureDetail' + description: '' + /api/v2/pal-park-area/: + get: + operationId: pal_park_area_list + description: Areas used for grouping Pokémon encounters in Pal Park. They're + like habitats that are specific to Pal Park. + summary: List pal park areas + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPalParkAreaSummaryList' + description: '' + /api/v2/pal-park-area/{id}/: + get: + operationId: pal_park_area_retrieve + description: Areas used for grouping Pokémon encounters in Pal Park. They're + like habitats that are specific to Pal Park. + summary: Get pal park area + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PalParkAreaDetail' + description: '' + /api/v2/pokedex/: + get: + operationId: pokedex_list + description: A Pokédex is a handheld electronic encyclopedia device; one which + is capable of recording and retaining information of the various Pokémon in + a given region with the exception of the national dex and some smaller dexes + related to portions of a region. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pokedex) + for greater detail. + summary: List pokedex + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokedexSummaryList' + description: '' + /api/v2/pokedex/{id}/: + get: + operationId: pokedex_retrieve + description: A Pokédex is a handheld electronic encyclopedia device; one which + is capable of recording and retaining information of the various Pokémon in + a given region with the exception of the national dex and some smaller dexes + related to portions of a region. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pokedex) + for greater detail. + summary: Get pokedex + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokedexDetail' + description: '' + /api/v2/pokemon/: + get: + operationId: pokemon_list + description: Pokémon are the creatures that inhabit the world of the Pokémon + games. They can be caught using Pokéballs and trained by battling with other + Pokémon. Each Pokémon belongs to a specific species but may take on a variant + which makes it differ from other Pokémon of the same species, such as base + stats, available abilities and typings. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_(species)) + for greater detail. + summary: List pokemon + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokemonSummaryList' + description: '' + /api/v2/pokemon/{id}/: + get: + operationId: pokemon_retrieve + description: Pokémon are the creatures that inhabit the world of the Pokémon + games. They can be caught using Pokéballs and trained by battling with other + Pokémon. Each Pokémon belongs to a specific species but may take on a variant + which makes it differ from other Pokémon of the same species, such as base + stats, available abilities and typings. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_(species)) + for greater detail. + summary: Get pokemon + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokemonDetail' + description: '' + /api/v2/pokemon-color/: + get: + operationId: pokemon_color_list + description: Colors used for sorting Pokémon in a Pokédex. The color listed + in the Pokédex is usually the color most apparent or covering each Pokémon's + body. No orange category exists; Pokémon that are primarily orange are listed + as red or brown. + summary: List pokemon colors + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokemonColorSummaryList' + description: '' + /api/v2/pokemon-color/{id}/: + get: + operationId: pokemon_color_retrieve + description: Colors used for sorting Pokémon in a Pokédex. The color listed + in the Pokédex is usually the color most apparent or covering each Pokémon's + body. No orange category exists; Pokémon that are primarily orange are listed + as red or brown. + summary: Get pokemon color + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokemonColorDetail' + description: '' + /api/v2/pokemon-form/: + get: + operationId: pokemon_form_list + description: Some Pokémon may appear in one of multiple, visually different + forms. These differences are purely cosmetic. For variations within a Pokémon + species, which do differ in more than just visuals, the 'Pokémon' entity is + used to represent such a variety. + summary: List pokemon forms + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokemonFormSummaryList' + description: '' + /api/v2/pokemon-form/{id}/: + get: + operationId: pokemon_form_retrieve + description: Some Pokémon may appear in one of multiple, visually different + forms. These differences are purely cosmetic. For variations within a Pokémon + species, which do differ in more than just visuals, the 'Pokémon' entity is + used to represent such a variety. + summary: Get pokemon form + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokemonFormDetail' + description: '' + /api/v2/pokemon-habitat/: + get: + operationId: pokemon_habitat_list + description: Habitats are generally different terrain Pokémon can be found in + but can also be areas designated for rare or legendary Pokémon. + summary: List pokemom habitas + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokemonHabitatSummaryList' + description: '' + /api/v2/pokemon-habitat/{id}/: + get: + operationId: pokemon_habitat_retrieve + description: Habitats are generally different terrain Pokémon can be found in + but can also be areas designated for rare or legendary Pokémon. + summary: Get pokemom habita + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokemonHabitatDetail' + description: '' + /api/v2/pokemon-shape/: + get: + operationId: pokemon_shape_list + description: Shapes used for sorting Pokémon in a Pokédex. + summary: List pokemon shapes + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokemonShapeSummaryList' + description: '' + /api/v2/pokemon-shape/{id}/: + get: + operationId: pokemon_shape_retrieve + description: Shapes used for sorting Pokémon in a Pokédex. + summary: Get pokemon shape + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokemonShapeDetail' + description: '' + /api/v2/pokemon-species/: + get: + operationId: pokemon_species_list + description: A Pokémon Species forms the basis for at least one Pokémon. Attributes + of a Pokémon species are shared across all varieties of Pokémon within the + species. A good example is Wormadam; Wormadam is the species which can be + found in three different varieties, Wormadam-Trash, Wormadam-Sandy and Wormadam-Plant. + summary: List pokemon species + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokemonSpeciesSummaryList' + description: '' + /api/v2/pokemon-species/{id}/: + get: + operationId: pokemon_species_retrieve + description: A Pokémon Species forms the basis for at least one Pokémon. Attributes + of a Pokémon species are shared across all varieties of Pokémon within the + species. A good example is Wormadam; Wormadam is the species which can be + found in three different varieties, Wormadam-Trash, Wormadam-Sandy and Wormadam-Plant. + summary: Get pokemon species + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokemonSpeciesDetail' + description: '' + /api/v2/pokeathlon-stat/: + get: + operationId: pokeathlon_stat_list + description: Pokeathlon Stats are different attributes of a Pokémon's performance + in Pokéathlons. In Pokéathlons, competitions happen on different courses; + one for each of the different Pokéathlon stats. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9athlon) + for greater detail. + summary: List pokeathlon stats + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedPokeathlonStatSummaryList' + description: '' + /api/v2/pokeathlon-stat/{id}/: + get: + operationId: pokeathlon_stat_retrieve + description: Pokeathlon Stats are different attributes of a Pokémon's performance + in Pokéathlons. In Pokéathlons, competitions happen on different courses; + one for each of the different Pokéathlon stats. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9athlon) + for greater detail. + summary: Get pokeathlon stat + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PokeathlonStatDetail' + description: '' + /api/v2/region/: + get: + operationId: region_list + description: A region is an organized area of the Pokémon world. Most often, + the main difference between regions is the species of Pokémon that can be + encountered within them. + summary: List regions + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedRegionSummaryList' + description: '' + /api/v2/region/{id}/: + get: + operationId: region_retrieve + description: A region is an organized area of the Pokémon world. Most often, + the main difference between regions is the species of Pokémon that can be + encountered within them. + summary: Get region + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - location + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/RegionDetail' + description: '' + /api/v2/stat/: + get: + operationId: stat_list + description: Stats determine certain aspects of battles. Each Pokémon has a + value for each stat which grows as they gain levels and can be altered momentarily + by effects in battles. + summary: List stats + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedStatSummaryList' + description: '' + /api/v2/stat/{id}/: + get: + operationId: stat_retrieve + description: Stats determine certain aspects of battles. Each Pokémon has a + value for each stat which grows as they gain levels and can be altered momentarily + by effects in battles. + summary: Get stat + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/StatDetail' + description: '' + /api/v2/super-contest-effect/: + get: + operationId: super_contest_effect_list + description: Super contest effects refer to the effects of moves when used in + super contests. + summary: List super contest effects + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - contests + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedSuperContestEffectSummaryList' + description: '' + /api/v2/super-contest-effect/{id}/: + get: + operationId: super_contest_effect_retrieve + description: Super contest effects refer to the effects of moves when used in + super contests. + summary: Get super contest effect + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - contests + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/SuperContestEffectDetail' + description: '' + /api/v2/type/: + get: + operationId: type_list + description: 'Types are properties for Pokémon and their moves. Each type has + three properties: which types of Pokémon it is super effective against, which + types of Pokémon it is not very effective against, and which types of Pokémon + it is completely ineffective against.' + summary: List types + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedTypeSummaryList' + description: '' + /api/v2/type/{id}/: + get: + operationId: type_retrieve + description: 'Types are properties for Pokémon and their moves. Each type has + three properties: which types of Pokémon it is super effective against, which + types of Pokémon it is not very effective against, and which types of Pokémon + it is completely ineffective against.' + summary: Get types + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - pokemon + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/TypeDetail' + description: '' + /api/v2/version/: + get: + operationId: version_list + description: Versions of the games, e.g., Red, Blue or Yellow. + summary: List versions + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedVersionSummaryList' + description: '' + /api/v2/version/{id}/: + get: + operationId: version_retrieve + description: Versions of the games, e.g., Red, Blue or Yellow. + summary: Get version + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/VersionDetail' + description: '' + /api/v2/version-group/: + get: + operationId: version_group_list + description: Version groups categorize highly similar versions of the games. + summary: List version groups + parameters: + - name: limit + required: false + in: query + description: Number of results to return per page. + schema: + type: integer + - name: offset + required: false + in: query + description: The initial index from which to return the results. + schema: + type: integer + - in: query + name: q + schema: + type: string + description: "> Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2)\n\ + Case-insensitive query applied on the `name` property. " + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/PaginatedVersionGroupSummaryList' + description: '' + /api/v2/version-group/{id}/: + get: + operationId: version_group_retrieve + description: Version groups categorize highly similar versions of the games. + summary: Get version group + parameters: + - in: path + name: id + schema: + type: string + description: This parameter can be a string or an integer. + required: true + tags: + - games + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + $ref: '#/components/schemas/VersionGroupDetail' + description: '' + /api/v2/pokemon/{pokemon_id}/encounters: + get: + operationId: pokemon_encounters_retrieve + description: Handles Pokemon Encounters as a sub-resource. + summary: Get pokemon encounter + parameters: + - in: path + name: pokemon_id + schema: + type: string + pattern: ^\d+$ + required: true + tags: + - encounters + security: + - cookieAuth: [] + - basicAuth: [] + - {} + responses: + '200': + content: + application/json: + schema: + type: array + items: + type: object + required: + - location_area + - version_details + properties: + location_area: + type: object + required: + - name + - url + properties: + name: + type: string + example: cerulean-city-area + url: + type: string + format: uri + example: https://pokeapi.co/api/v2/location-area/281/ + version_details: + type: array + items: + type: object + required: + - encounter_details + - max_chance + - version + properties: + encounter_details: + type: array + items: + type: object + required: + - chance + - condition_values + - max_level + - method + - min_level + properties: + chance: + type: number + example: 100 + condition_values: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + example: story-progress-beat-red + url: + type: string + format: uri + example: https://pokeapi.co/api/v2/encounter-condition-value/55/ + max_level: + type: number + example: 10 + method: + type: object + required: + - name + - url + properties: + name: + type: string + example: gift + url: + type: string + format: uri + example: https://pokeapi.co/api/v2/encounter-method/18/ + min_level: + type: number + example: 10 + max_chance: + type: number + example: 100 + version: + type: object + required: + - name + - url + properties: + name: + type: string + example: red + url: + type: string + format: uri + example: https://pokeapi.co/api/v2/version/1/ + description: '' +components: + schemas: + AbilityChange: + type: object + properties: + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + effect_entries: + type: array + items: + $ref: '#/components/schemas/AbilityChangeEffectText' + readOnly: true + required: + - effect_entries + - version_group + AbilityChangeEffectText: + type: object + properties: + effect: + type: string + maxLength: 6000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - effect + - language + AbilityDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + is_main_series: + type: boolean + generation: + $ref: '#/components/schemas/GenerationSummary' + names: + type: array + items: + $ref: '#/components/schemas/AbilityName' + readOnly: true + effect_entries: + type: array + items: + $ref: '#/components/schemas/AbilityEffectText' + readOnly: true + effect_changes: + type: array + items: + $ref: '#/components/schemas/AbilityChange' + readOnly: true + flavor_text_entries: + type: array + items: + $ref: '#/components/schemas/AbilityFlavorText' + readOnly: true + pokemon: + type: array + items: + type: object + required: + - is_hidden + - slot + - pokemon + properties: + is_hidden: + type: boolean + slot: + type: integer + format: int32 + examples: + - 3 + pokemon: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - gloom + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon/44/ + readOnly: true + required: + - effect_changes + - effect_entries + - flavor_text_entries + - generation + - id + - name + - names + - pokemon + AbilityEffectText: + type: object + properties: + effect: + type: string + maxLength: 6000 + short_effect: + type: string + maxLength: 300 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - effect + - language + - short_effect + AbilityFlavorText: + type: object + properties: + flavor_text: + type: string + language: + $ref: '#/components/schemas/LanguageSummary' + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + required: + - flavor_text + - language + - version_group + AbilityName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + AbilitySummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + BerryDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + growth_time: + type: integer + max_harvest: + type: integer + natural_gift_power: + type: integer + size: + type: integer + smoothness: + type: integer + soil_dryness: + type: integer + firmness: + $ref: '#/components/schemas/BerryFirmnessSummary' + flavors: + type: array + items: + type: object + required: + - potency + - flavor + properties: + potency: + type: integer + examples: + - 10 + flavor: + type: object + require: + - name + - url + properties: + name: + type: string + description: The name of the flavor + examples: + - spicy + url: + type: string + format: uri + description: The URL to get more information about the flavor + examples: + - https://pokeapi.co/api/v2/berry-flavor/1/ + readOnly: true + item: + $ref: '#/components/schemas/ItemSummary' + natural_gift_type: + $ref: '#/components/schemas/TypeSummary' + required: + - firmness + - flavors + - growth_time + - id + - item + - max_harvest + - name + - natural_gift_power + - natural_gift_type + - size + - smoothness + - soil_dryness + BerryFirmnessDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + berries: + type: array + items: + $ref: '#/components/schemas/BerrySummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/BerryFirmnessName' + readOnly: true + required: + - berries + - id + - name + - names + BerryFirmnessName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + BerryFirmnessSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + BerryFlavorDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + berries: + type: array + items: + type: object + required: + - potency + - berry + properties: + potency: + type: integer + examples: + - 10 + berry: + type: object + require: + - name + - url + properties: + name: + type: string + description: The name of the berry + examples: + - rowap + url: + type: string + format: uri + description: The URL to get more information about the berry + examples: + - https://pokeapi.co/api/v2/berry/64/ + readOnly: true + contest_type: + $ref: '#/components/schemas/ContestTypeSummary' + names: + type: array + items: + $ref: '#/components/schemas/BerryFlavorName' + readOnly: true + required: + - berries + - contest_type + - id + - name + - names + BerryFlavorName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + BerryFlavorSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + BerrySummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + CharacteristicDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + CharacteristicDetail: + type: object + properties: + id: + type: integer + readOnly: true + gene_modulo: + type: integer + possible_values: + type: array + items: + type: integer + format: int32 + examples: + - - 0 + - 5 + - 10 + - 15 + - 20 + - 25 + - 30 + readOnly: true + highest_stat: + $ref: '#/components/schemas/StatSummary' + descriptions: + type: array + items: + $ref: '#/components/schemas/CharacteristicDescription' + readOnly: true + required: + - descriptions + - gene_modulo + - highest_stat + - id + - possible_values + CharacteristicSummary: + type: object + properties: + url: + type: string + format: uri + readOnly: true + required: + - url + ContestEffectDetail: + type: object + properties: + id: + type: integer + readOnly: true + appeal: + type: integer + jam: + type: integer + effect_entries: + type: array + items: + $ref: '#/components/schemas/ContestEffectEffectText' + readOnly: true + flavor_text_entries: + type: array + items: + $ref: '#/components/schemas/ContestEffectFlavorText' + readOnly: true + required: + - appeal + - effect_entries + - flavor_text_entries + - id + - jam + ContestEffectEffectText: + type: object + properties: + effect: + type: string + maxLength: 6000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - effect + - language + ContestEffectFlavorText: + type: object + properties: + flavor_text: + type: string + maxLength: 500 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - flavor_text + - language + ContestEffectSummary: + type: object + properties: + url: + type: string + format: uri + readOnly: true + required: + - url + ContestTypeDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + berry_flavor: + allOf: + - $ref: '#/components/schemas/BerryFlavorSummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/ContestTypeName' + readOnly: true + required: + - berry_flavor + - id + - name + - names + ContestTypeName: + type: object + properties: + name: + type: string + maxLength: 100 + color: + type: string + maxLength: 10 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - color + - language + - name + ContestTypeSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + EggGroupDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/EggGroupName' + readOnly: true + pokemon_species: + type: array + items: + type: object + required: + - potency + - flavor + properties: + name: + type: string + description: Pokemon species name. + examples: + - bulbasaur + url: + type: string + format: uri + description: The URL to get more information about the species + examples: + - https://pokeapi.co/api/v2/pokemon-species/1/ + readOnly: true + required: + - id + - name + - names + - pokemon_species + EggGroupName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + EggGroupSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + EncounterConditionDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + values: + type: array + items: + $ref: '#/components/schemas/EncounterConditionValueSummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/EncounterConditionName' + readOnly: true + required: + - id + - name + - names + - values + EncounterConditionName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + EncounterConditionSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + EncounterConditionValueDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + condition: + $ref: '#/components/schemas/EncounterConditionSummary' + names: + type: array + items: + $ref: '#/components/schemas/EncounterConditionValueName' + readOnly: true + required: + - condition + - id + - name + - names + EncounterConditionValueName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + EncounterConditionValueSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + EncounterMethodDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + order: + type: + - integer + - 'null' + names: + type: array + items: + $ref: '#/components/schemas/EncounterMethodName' + readOnly: true + required: + - id + - name + - names + EncounterMethodName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + EncounterMethodSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + EvolutionChainDetail: + type: object + properties: + id: + type: integer + readOnly: true + baby_trigger_item: + $ref: '#/components/schemas/ItemSummary' + chain: + type: object + required: + - evolution_details + - evolves_to + - is_baby + - species + properties: + evolution_details: + type: array + items: {} + examples: [] + evolves_to: + type: array + items: + type: object + required: + - evolution_details + - evolves_to + - is_baby + - species + properties: + evolution_details: + type: array + items: + type: object + required: + - gender + - held_item + - item + - known_move + - known_move_type + - location + - min_affection + - min_beauty + - min_happiness + - min_level + - needs_overworld_rain + - party_species + - party_type + - relative_physical_stats + - time_of_day + - trade_species + - trigger + - turn_upside_down + properties: + gender: + type: object + nullable: true + required: + - name + - url + properties: + name: + type: string + examples: + - 1 + url: + type: string + format: uri + examples: + - 2 + held_item: + type: object + nullable: true + required: + - name + - url + properties: + name: + type: string + examples: + - 1 + url: + type: string + format: uri + examples: + - 2 + item: + type: object + nullable: true + required: + - name + - url + properties: + name: + type: string + examples: + - 1 + url: + type: string + format: uri + examples: + - 2 + known_move: + type: '' + nullable: true + known_move_type: + type: '' + nullable: true + location: + type: object + nullable: true + required: + - name + - url + properties: + name: + type: string + url: + type: string + format: uri + min_affection: + type: integer + format: int32 + nullable: true + min_beauty: + type: integer + format: int32 + nullable: true + min_happiness: + type: integer + format: int32 + nullable: true + min_level: + type: integer + format: int32 + nullable: true + needs_overworld_rain: + type: boolean + nullable: true + party_species: + type: string + nullable: true + party_type: + type: string + nullable: true + relative_physical_stats: + type: string + nullable: true + time_of_day: + type: string + trade_species: + type: string + nullable: true + trigger: + type: object + required: + - name + - url + properties: + name: + type: string + url: + type: string + format: uri + turn_upside_down: + type: boolean + is_baby: + type: boolean + species: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - happiny + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon-species/440/ + is_baby: + type: boolean + species: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - happiny + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon-species/440/ + readOnly: true + required: + - baby_trigger_item + - chain + - id + EvolutionChainSummary: + type: object + properties: + url: + type: string + format: uri + readOnly: true + required: + - url + EvolutionTriggerDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/EvolutionTriggerName' + readOnly: true + pokemon_species: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - ivysaur + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon-species/2/ + readOnly: true + required: + - id + - name + - names + - pokemon_species + EvolutionTriggerName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + EvolutionTriggerSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + Experience: + type: object + properties: + level: + type: integer + experience: + type: integer + required: + - experience + - level + GenderDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + pokemon_species_details: + type: array + items: + type: object + required: + - rate + - pokemon_species + properties: + rate: + type: integer + format: int32 + examples: + - 1 + pokemon_species: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bulbasaur + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon-species/1/ + readOnly: true + required_for_evolution: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - wormadam + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon-species/413/ + readOnly: true + required: + - id + - name + - pokemon_species_details + - required_for_evolution + GenderSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + GenerationDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + abilities: + type: array + items: + $ref: '#/components/schemas/AbilitySummary' + readOnly: true + main_region: + $ref: '#/components/schemas/RegionSummary' + moves: + type: array + items: + $ref: '#/components/schemas/MoveSummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/GenerationName' + readOnly: true + pokemon_species: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesSummary' + readOnly: true + types: + type: array + items: + $ref: '#/components/schemas/TypeSummary' + readOnly: true + version_groups: + type: array + items: + $ref: '#/components/schemas/VersionGroupSummary' + readOnly: true + required: + - abilities + - id + - main_region + - moves + - name + - names + - pokemon_species + - types + - version_groups + GenerationName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + GenerationSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + GrowthRateDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + GrowthRateDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + formula: + type: string + maxLength: 500 + descriptions: + type: array + items: + $ref: '#/components/schemas/GrowthRateDescription' + readOnly: true + levels: + type: array + items: + $ref: '#/components/schemas/Experience' + readOnly: true + pokemon_species: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesSummary' + readOnly: true + required: + - descriptions + - formula + - id + - levels + - name + - pokemon_species + GrowthRateSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + ItemAttributeDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + ItemAttributeDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + descriptions: + type: array + items: + $ref: '#/components/schemas/ItemAttributeDescription' + readOnly: true + items: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - master-ball + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/item/1/ + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/ItemAttributeName' + readOnly: true + required: + - descriptions + - id + - items + - name + - names + ItemAttributeName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + ItemAttributeSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + ItemCategoryDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + items: + type: array + items: + $ref: '#/components/schemas/ItemSummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/ItemCategoryName' + readOnly: true + pocket: + $ref: '#/components/schemas/ItemPocketSummary' + required: + - id + - items + - name + - names + - pocket + ItemCategoryName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + ItemCategorySummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + ItemDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + cost: + type: + - integer + - 'null' + fling_power: + type: + - integer + - 'null' + fling_effect: + $ref: '#/components/schemas/ItemFlingEffectSummary' + attributes: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - countable + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/item-attribute/1/ + readOnly: true + category: + $ref: '#/components/schemas/ItemCategorySummary' + effect_entries: + type: array + items: + $ref: '#/components/schemas/ItemEffectText' + readOnly: true + flavor_text_entries: + type: array + items: + $ref: '#/components/schemas/ItemFlavorText' + readOnly: true + game_indices: + type: array + items: + $ref: '#/components/schemas/ItemGameIndex' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/ItemName' + readOnly: true + held_by_pokemon: + type: array + items: + type: object + required: + - pokemon + - version-details + properties: + pokemon: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - farfetchd + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon/83/ + version-details: + type: array + items: + type: object + required: + - rarity + - version + properties: + rarity: + type: integer + format: int32 + examples: + - 5 + version: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - ruby + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version/7/ + readOnly: true + sprites: + type: object + required: + - default + properties: + default: + type: string + format: uri + examples: + - https://pokeapi.co/media/sprites/items/master-ball.png + readOnly: true + baby_trigger_for: + type: object + required: + - url + properties: + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/evolution-chain/51/ + readOnly: true + machines: + type: array + items: + type: object + required: + - machine + - version_group + properties: + machine: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/machine/1/ + version_group: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - sword-shield + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version-group/20/ + readOnly: true + required: + - attributes + - baby_trigger_for + - category + - effect_entries + - flavor_text_entries + - fling_effect + - game_indices + - held_by_pokemon + - id + - machines + - name + - names + - sprites + ItemEffectText: + type: object + properties: + effect: + type: string + maxLength: 6000 + short_effect: + type: string + maxLength: 300 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - effect + - language + - short_effect + ItemFlavorText: + type: object + properties: + text: + type: string + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - text + - version_group + ItemFlingEffectDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + effect_entries: + type: array + items: + $ref: '#/components/schemas/ItemFlingEffectEffectText' + readOnly: true + items: + type: array + items: + $ref: '#/components/schemas/ItemSummary' + readOnly: true + required: + - effect_entries + - id + - items + - name + ItemFlingEffectEffectText: + type: object + properties: + effect: + type: string + maxLength: 6000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - effect + - language + ItemFlingEffectSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + ItemGameIndex: + type: object + properties: + game_index: + type: integer + generation: + $ref: '#/components/schemas/GenerationSummary' + required: + - game_index + - generation + ItemName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + ItemPocketDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + categories: + type: array + items: + $ref: '#/components/schemas/ItemCategorySummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/ItemPocketName' + readOnly: true + required: + - categories + - id + - name + - names + ItemPocketName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + ItemPocketSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + ItemSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + LanguageDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + official: + type: boolean + iso639: + type: string + maxLength: 10 + iso3166: + type: string + maxLength: 2 + names: + type: array + items: + $ref: '#/components/schemas/LanguageName' + readOnly: true + required: + - id + - iso3166 + - iso639 + - name + - names + LanguageName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + LanguageSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + LocationAreaDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + game_index: + type: integer + encounter_method_rates: + type: array + items: + type: object + required: + - encounter_method + - version_details + properties: + encounter_method: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - old-rod + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/encounter-method/2/ + version_details: + type: array + items: + type: object + required: + - rate + - version + properties: + rate: + type: integer + format: int32 + examples: + - 5 + version: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - platinum + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version/14/ + readOnly: true + location: + $ref: '#/components/schemas/LocationSummary' + names: + type: array + items: + $ref: '#/components/schemas/LocationAreaName' + readOnly: true + pokemon_encounters: + type: array + items: + type: object + required: + - pokemon + - version_details + properties: + pokemon: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - tentacool + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon/72/ + version_details: + type: array + items: + type: object + required: + - version + - max_chance + - encounter_details + properties: + version: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - diamond + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version/12/ + max_chance: + type: integer + format: int32 + examples: + - 60 + encounter_details: + type: object + required: + - min_level + - max_level + - condition_value + - chance + - method + properties: + min_level: + type: integer + format: int32 + examples: + - 20 + max_level: + type: integer + format: int32 + examples: + - 30 + condition_values: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - slot2-sapphire + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/encounter-condition-value/10/ + chance: + type: integer + format: int32 + examples: + - 60 + method: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - surf + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/encounter-method/5/ + readOnly: true + required: + - encounter_method_rates + - game_index + - id + - location + - name + - names + - pokemon_encounters + LocationAreaName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + LocationAreaSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + LocationDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + region: + $ref: '#/components/schemas/RegionSummary' + names: + type: array + items: + $ref: '#/components/schemas/LocationName' + readOnly: true + game_indices: + type: array + items: + $ref: '#/components/schemas/LocationGameIndex' + readOnly: true + areas: + type: array + items: + $ref: '#/components/schemas/LocationAreaSummary' + readOnly: true + required: + - areas + - game_indices + - id + - name + - names + - region + LocationGameIndex: + type: object + properties: + game_index: + type: integer + generation: + $ref: '#/components/schemas/GenerationSummary' + required: + - game_index + - generation + LocationName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + LocationSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + MachineDetail: + type: object + properties: + id: + type: integer + readOnly: true + item: + $ref: '#/components/schemas/ItemSummary' + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + move: + $ref: '#/components/schemas/MoveSummary' + required: + - id + - item + - move + - version_group + MachineSummary: + type: object + properties: + url: + type: string + format: uri + readOnly: true + required: + - url + MoveBattleStyleDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/MoveBattleStyleName' + readOnly: true + required: + - id + - name + - names + MoveBattleStyleName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + MoveBattleStyleSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + MoveChange: + type: object + properties: + accuracy: + type: + - integer + - 'null' + power: + type: + - integer + - 'null' + pp: + type: + - integer + - 'null' + effect_chance: + type: integer + effect_entries: + type: array + items: + type: object + required: + - effect + - short_effect + - language + properties: + effect: + type: string + examples: + - Inflicts [regular damage]{mechanic:regular-damage}. + short_effect: + type: string + examples: + - Inflicts regular damage with no additional effect. + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + readOnly: true + type: + $ref: '#/components/schemas/TypeSummary' + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + required: + - effect_chance + - effect_entries + - type + - version_group + MoveDamageClassDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + MoveDamageClassDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + descriptions: + type: array + items: + $ref: '#/components/schemas/MoveDamageClassDescription' + readOnly: true + moves: + type: array + items: + $ref: '#/components/schemas/MoveSummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/MoveDamageClassName' + readOnly: true + required: + - descriptions + - id + - moves + - name + - names + MoveDamageClassName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + MoveDamageClassSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + MoveDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + accuracy: + type: + - integer + - 'null' + effect_chance: + type: integer + pp: + type: + - integer + - 'null' + priority: + type: + - integer + - 'null' + power: + type: + - integer + - 'null' + contest_combos: + type: object + required: + - normal + - super + properties: + normal: + type: object + required: + - use_before + - use_after + properties: + use_before: + type: array + nullable: true + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - fire-punch + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/7/ + use_after: + type: array + nullable: true + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - ice-punch + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/8/ + super: + type: object + required: + - use_before + - use_after + properties: + use_before: + type: array + nullable: true + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - night-slash + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/400/ + use_after: + type: array + nullable: true + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - focus-energy + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/116/ + readOnly: true + contest_type: + $ref: '#/components/schemas/ContestTypeSummary' + contest_effect: + $ref: '#/components/schemas/ContestEffectSummary' + damage_class: + $ref: '#/components/schemas/MoveDamageClassSummary' + effect_entries: + type: array + items: + type: object + required: + - effect + - short_effect + - language + properties: + effect: + type: string + examples: + - Inflicts [regular damage]{mechanic:regular-damage}. + short_effect: + type: string + examples: + - Inflicts regular damage with no additional effect. + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + readOnly: true + effect_changes: + type: array + items: + type: object + required: + - effect_entries + - version_group + properties: + effect_entries: + type: array + items: + type: object + required: + - effect + - language + properties: + effect: + type: string + examples: + - Hits Pokémon under the effects of dig and fly. + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + version_group: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - gold-silver + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version-group/3/ + readOnly: true + generation: + $ref: '#/components/schemas/GenerationSummary' + meta: + allOf: + - $ref: '#/components/schemas/MoveMeta' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/MoveName' + readOnly: true + past_values: + type: array + items: + $ref: '#/components/schemas/MoveChange' + readOnly: true + stat_changes: + type: array + items: + type: object + required: + - change + - stat + properties: + change: + type: integer + format: int32 + examples: + - 2 + stat: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - attack + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/stat/1/ + readOnly: true + super_contest_effect: + $ref: '#/components/schemas/SuperContestEffectSummary' + target: + $ref: '#/components/schemas/MoveTargetSummary' + type: + $ref: '#/components/schemas/TypeSummary' + machines: + type: array + items: + type: object + required: + - machine + - version_group + properties: + machine: + type: object + required: + - url + properties: + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/machine/1/ + version_group: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - sword-shield + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version-group/1/ + readOnly: true + flavor_text_entries: + type: array + items: + $ref: '#/components/schemas/MoveFlavorText' + readOnly: true + learned_by_pokemon: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - clefairy + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon/35/ + readOnly: true + required: + - contest_combos + - contest_effect + - contest_type + - damage_class + - effect_chance + - effect_changes + - effect_entries + - flavor_text_entries + - generation + - id + - learned_by_pokemon + - machines + - meta + - name + - names + - past_values + - stat_changes + - super_contest_effect + - target + - type + MoveFlavorText: + type: object + properties: + flavor_text: + type: string + language: + $ref: '#/components/schemas/LanguageSummary' + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + required: + - flavor_text + - language + - version_group + MoveLearnMethodDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + MoveLearnMethodDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/MoveLearnMethodName' + readOnly: true + descriptions: + type: array + items: + $ref: '#/components/schemas/MoveLearnMethodDescription' + readOnly: true + version_groups: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - red-blue + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version-group/1/ + readOnly: true + required: + - descriptions + - id + - name + - names + - version_groups + MoveLearnMethodName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + MoveLearnMethodSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + MoveMeta: + type: object + properties: + ailment: + $ref: '#/components/schemas/MoveMetaAilmentSummary' + category: + $ref: '#/components/schemas/MoveMetaCategorySummary' + min_hits: + type: + - integer + - 'null' + max_hits: + type: + - integer + - 'null' + min_turns: + type: + - integer + - 'null' + max_turns: + type: + - integer + - 'null' + drain: + type: + - integer + - 'null' + healing: + type: + - integer + - 'null' + crit_rate: + type: + - integer + - 'null' + ailment_chance: + type: + - integer + - 'null' + flinch_chance: + type: + - integer + - 'null' + stat_chance: + type: + - integer + - 'null' + required: + - ailment + - category + MoveMetaAilmentDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + moves: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - thunder-punch + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/9/ + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/MoveMetaAilmentName' + readOnly: true + required: + - id + - moves + - name + - names + MoveMetaAilmentName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + MoveMetaAilmentSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + MoveMetaCategoryDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + MoveMetaCategoryDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + descriptions: + type: array + items: + $ref: '#/components/schemas/MoveMetaCategoryDescription' + readOnly: true + moves: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - sing + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/47/ + readOnly: true + required: + - descriptions + - id + - moves + - name + MoveMetaCategorySummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + MoveName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + MoveSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + MoveTargetDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + MoveTargetDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + descriptions: + type: array + items: + $ref: '#/components/schemas/MoveTargetDescription' + readOnly: true + moves: + type: array + items: + $ref: '#/components/schemas/MoveSummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/MoveTargetName' + readOnly: true + required: + - descriptions + - id + - moves + - name + - names + MoveTargetName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + MoveTargetSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + NatureBattleStylePreference: + type: object + properties: + low_hp_preference: + type: integer + high_hp_preference: + type: integer + move_battle_style: + $ref: '#/components/schemas/MoveBattleStyleSummary' + required: + - high_hp_preference + - low_hp_preference + - move_battle_style + NatureDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + decreased_stat: + $ref: '#/components/schemas/StatSummary' + increased_stat: + $ref: '#/components/schemas/StatSummary' + likes_flavor: + $ref: '#/components/schemas/BerryFlavorSummary' + hates_flavor: + $ref: '#/components/schemas/BerryFlavorSummary' + berries: + type: array + items: + $ref: '#/components/schemas/BerrySummary' + readOnly: true + pokeathlon_stat_changes: + type: array + items: + type: object + required: + - max_change + - pokeathlon_stat + properties: + max_change: + type: integer + format: int32 + examples: + - 1 + pokeathlon_stat: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - power + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokeathlon-stat/2/ + readOnly: true + move_battle_style_preferences: + type: array + items: + $ref: '#/components/schemas/NatureBattleStylePreference' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/NatureName' + readOnly: true + required: + - berries + - decreased_stat + - hates_flavor + - id + - increased_stat + - likes_flavor + - move_battle_style_preferences + - name + - names + - pokeathlon_stat_changes + NatureName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + NatureSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PaginatedAbilitySummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/AbilitySummary' + PaginatedBerryFirmnessSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/BerryFirmnessSummary' + PaginatedBerryFlavorSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/BerryFlavorSummary' + PaginatedBerrySummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/BerrySummary' + PaginatedCharacteristicSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/CharacteristicSummary' + PaginatedContestEffectSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/ContestEffectSummary' + PaginatedContestTypeSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/ContestTypeSummary' + PaginatedEggGroupSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/EggGroupSummary' + PaginatedEncounterConditionSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/EncounterConditionSummary' + PaginatedEncounterConditionValueSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/EncounterConditionValueSummary' + PaginatedEncounterMethodSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/EncounterMethodSummary' + PaginatedEvolutionChainSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/EvolutionChainSummary' + PaginatedEvolutionTriggerSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/EvolutionTriggerSummary' + PaginatedGenderSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/GenderSummary' + PaginatedGenerationSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/GenerationSummary' + PaginatedGrowthRateSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/GrowthRateSummary' + PaginatedItemAttributeSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/ItemAttributeSummary' + PaginatedItemCategorySummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/ItemCategorySummary' + PaginatedItemFlingEffectSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/ItemFlingEffectSummary' + PaginatedItemPocketSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/ItemPocketSummary' + PaginatedItemSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/ItemSummary' + PaginatedLanguageSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/LanguageSummary' + PaginatedLocationAreaSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/LocationAreaSummary' + PaginatedLocationSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/LocationSummary' + PaginatedMachineSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MachineSummary' + PaginatedMoveBattleStyleSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MoveBattleStyleSummary' + PaginatedMoveDamageClassSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MoveDamageClassSummary' + PaginatedMoveLearnMethodSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MoveLearnMethodSummary' + PaginatedMoveMetaAilmentSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MoveMetaAilmentSummary' + PaginatedMoveMetaCategorySummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MoveMetaCategorySummary' + PaginatedMoveSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MoveSummary' + PaginatedMoveTargetSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/MoveTargetSummary' + PaginatedNatureSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/NatureSummary' + PaginatedPalParkAreaSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PalParkAreaSummary' + PaginatedPokeathlonStatSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokeathlonStatSummary' + PaginatedPokedexSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokedexSummary' + PaginatedPokemonColorSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokemonColorSummary' + PaginatedPokemonFormSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokemonFormSummary' + PaginatedPokemonHabitatSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokemonHabitatSummary' + PaginatedPokemonShapeSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokemonShapeSummary' + PaginatedPokemonSpeciesSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesSummary' + PaginatedPokemonSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/PokemonSummary' + PaginatedRegionSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/RegionSummary' + PaginatedStatSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/StatSummary' + PaginatedSuperContestEffectSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/SuperContestEffectSummary' + PaginatedTypeSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/TypeSummary' + PaginatedVersionGroupSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/VersionGroupSummary' + PaginatedVersionSummaryList: + type: object + properties: + count: + type: integer + example: 123 + next: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=400&limit=100 + previous: + type: string + nullable: true + format: uri + example: http://api.example.org/accounts/?offset=200&limit=100 + results: + type: array + items: + $ref: '#/components/schemas/VersionSummary' + PalParkAreaDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/PalParkAreaName' + readOnly: true + pokemon_encounters: + type: array + items: + type: object + required: + - base_score + - pokemon-species + - rate + properties: + base_score: + type: integer + format: int32 + examples: + - 50 + pokemon-species: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bulbasaur + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon-species/1/ + rate: + type: integer + format: int32 + examples: + - 30 + readOnly: true + required: + - id + - name + - names + - pokemon_encounters + PalParkAreaName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + PalParkAreaSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokeathlonStatDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + affecting_natures: + type: object + required: + - decrease + - increase + properties: + decrease: + type: array + items: + type: object + required: + - max_change + - nature + properties: + max_change: + type: integer + format: int32 + maximum: -1 + examples: + - -1 + nature: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - hardy + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/nature/1/ + increase: + type: array + items: + type: object + required: + - max_change + - nature + properties: + max_change: + type: integer + format: int32 + minimum: 1 + examples: + - 2 + nature: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - hardy + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/nature/1/ + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/PokeathlonStatName' + readOnly: true + required: + - affecting_natures + - id + - name + - names + PokeathlonStatName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + PokeathlonStatSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokedexDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + PokedexDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + is_main_series: + type: boolean + descriptions: + type: array + items: + $ref: '#/components/schemas/PokedexDescription' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/PokedexName' + readOnly: true + pokemon_entries: + type: array + items: + type: object + required: + - entry_number + - pokemon_species + properties: + entry_number: + type: integer + format: int32 + examples: + - 1 + pokemon_species: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bulbasaur + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon-species/1/ + readOnly: true + region: + $ref: '#/components/schemas/RegionSummary' + version_groups: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - the-teal-mask + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version-group/26/ + readOnly: true + required: + - descriptions + - id + - name + - names + - pokemon_entries + - region + - version_groups + PokedexName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + PokedexSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokemonColorDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/PokemonColorName' + readOnly: true + pokemon_species: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesSummary' + readOnly: true + required: + - id + - name + - names + - pokemon_species + PokemonColorName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + PokemonColorSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokemonDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + base_experience: + type: + - integer + - 'null' + height: + type: + - integer + - 'null' + is_default: + type: boolean + order: + type: + - integer + - 'null' + weight: + type: + - integer + - 'null' + abilities: + type: array + items: + type: object + required: + - ability + - is_hidden + - slot + properties: + ability: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - sand-veil + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/ability/8/ + is_hidden: + type: boolean + slot: + type: integer + format: int32 + examples: + - 1 + readOnly: true + past_abilities: + type: array + items: + type: object + required: + - abilities + - generation + properties: + abilities: + type: array + items: + type: object + required: + - ability + - is_hidden + - slot + properties: + ability: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - levitate + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/ability/26/ + is_hidden: + type: boolean + slot: + type: integer + format: int32 + examples: + - 1 + generation: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - generation-vi + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/generation/6/ + readOnly: true + forms: + type: array + items: + $ref: '#/components/schemas/PokemonFormSummary' + readOnly: true + game_indices: + type: array + items: + $ref: '#/components/schemas/PokemonGameIndex' + readOnly: true + held_items: + type: object + required: + - item + - version_details + properties: + item: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - soft-sand + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/item/214/ + version_details: + type: array + items: + type: object + required: + - rarity + - version + properties: + rarity: + type: integer + format: int32 + examples: + - 5 + version: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - diamond + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version/12/ + readOnly: true + location_area_encounters: + type: string + examples: + - https://pokeapi.co/api/v2/pokemon/1/encounters + readOnly: true + moves: + type: array + items: + type: object + required: + - move + - version_group_details + properties: + move: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - scratch + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/10/ + version_group_details: + type: array + items: + type: object + required: + - level_learned_at + - move_learn_method + - version_group + properties: + level_learned_at: + type: integer + format: int32 + examples: + - 1 + move_learn_method: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - level-up + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move-learn-method/1/ + version_group: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - red-blue + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version-group/1/ + readOnly: true + species: + $ref: '#/components/schemas/PokemonSpeciesSummary' + sprites: + type: object + properties: + front_default: + type: string + format: uri + exmaple: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/1.png + additionalProperties: + type: string + format: uri + nullable: true + examples: + - https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/shiny/1.png + examples: + - back_default: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/1.png + back_female: null + back_shiny: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/shiny/1.png + back_shiny_female: null + front_default: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/1.png + front_female: null + front_shiny: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/shiny/1.png + front_shiny_female: null + readOnly: true + cries: + type: object + required: + - latest + - legacy + properties: + latest: + type: string + format: uri + examples: + - https://raw.githubusercontent.com/PokeAPI/cries/main/cries/pokemon/latest/50.ogg + legacy: + type: string + format: uri + examples: + - https://raw.githubusercontent.com/PokeAPI/cries/main/cries/pokemon/legacy/50.ogg + readOnly: true + stats: + type: array + items: + $ref: '#/components/schemas/PokemonStat' + readOnly: true + types: + type: array + items: + type: object + required: + - slot + - type + properties: + slot: + type: integer + format: int32 + examples: + - 1 + type: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - ghost + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/8/ + readOnly: true + past_types: + type: array + items: + type: object + required: + - generation + - types + properties: + generation: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - generation-v + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/generation/5/ + types: + type: array + items: + type: object + required: + - slot + - type + properties: + slot: + type: integer + format: int32 + examples: + - 1 + type: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - normal + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/1/ + readOnly: true + required: + - abilities + - cries + - forms + - game_indices + - held_items + - id + - location_area_encounters + - moves + - name + - past_abilities + - past_types + - species + - sprites + - stats + - types + PokemonDexEntry: + type: object + properties: + entry_number: + type: integer + pokedex: + $ref: '#/components/schemas/PokedexSummary' + required: + - entry_number + - pokedex + PokemonFormDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + order: + type: + - integer + - 'null' + form_order: + type: + - integer + - 'null' + is_default: + type: boolean + is_battle_only: + type: boolean + is_mega: + type: boolean + form_name: + type: string + maxLength: 30 + pokemon: + $ref: '#/components/schemas/PokemonSummary' + sprites: + type: object + properties: + default: + type: string + format: uri + examples: + - https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/412.png + additionalProperties: + type: string + format: uri + nullable: true + examples: + - https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/shiny/412.png + examples: + - back_default: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/412.png + back_female: null + back_shiny: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/back/shiny/412.png + back_shiny_female: null + front_default: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/412.png + front_female: null + front_shiny: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/shiny/412.png + front_shiny_female: null + readOnly: true + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + form_names: + type: array + items: + type: object + required: + - language + - name + properties: + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + name: + type: string + examples: + - Plant Cloak + readOnly: true + names: + type: array + items: + type: object + required: + - language + - name + properties: + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + name: + type: string + examples: + - Plant Cloak + readOnly: true + types: + type: array + items: + type: object + required: + - slot + - type + properties: + slot: + type: integer + format: int32 + examples: + - 1 + type: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bug + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/7/ + readOnly: true + required: + - form_name + - form_names + - id + - name + - names + - pokemon + - sprites + - types + - version_group + PokemonFormSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokemonGameIndex: + type: object + properties: + game_index: + type: integer + version: + $ref: '#/components/schemas/VersionSummary' + required: + - game_index + - version + PokemonHabitatDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/PokemonHabitatName' + readOnly: true + pokemon_species: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesSummary' + readOnly: true + required: + - id + - name + - names + - pokemon_species + PokemonHabitatName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + PokemonHabitatSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokemonShapeDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + awesome_names: + type: array + items: + type: object + required: + - awesome_name + - language + properties: + awesome_name: + type: string + examples: + - Pomaceous + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + readOnly: true + names: + type: array + items: + type: object + required: + - url + - name + properties: + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + name: + type: string + examples: + - Ball + readOnly: true + pokemon_species: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesSummary' + readOnly: true + required: + - awesome_names + - id + - name + - names + - pokemon_species + PokemonShapeSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokemonSpeciesDescription: + type: object + properties: + description: + type: string + maxLength: 1000 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + PokemonSpeciesDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + order: + type: + - integer + - 'null' + gender_rate: + type: + - integer + - 'null' + capture_rate: + type: + - integer + - 'null' + base_happiness: + type: + - integer + - 'null' + is_baby: + type: boolean + is_legendary: + type: boolean + is_mythical: + type: boolean + hatch_counter: + type: + - integer + - 'null' + has_gender_differences: + type: boolean + forms_switchable: + type: boolean + growth_rate: + $ref: '#/components/schemas/GrowthRateSummary' + pokedex_numbers: + type: array + items: + $ref: '#/components/schemas/PokemonDexEntry' + readOnly: true + egg_groups: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - monster + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/egg-group/1/ + readOnly: true + color: + $ref: '#/components/schemas/PokemonColorSummary' + shape: + $ref: '#/components/schemas/PokemonShapeSummary' + evolves_from_species: + $ref: '#/components/schemas/PokemonSpeciesSummary' + evolution_chain: + $ref: '#/components/schemas/EvolutionChainSummary' + habitat: + $ref: '#/components/schemas/PokemonHabitatSummary' + generation: + $ref: '#/components/schemas/GenerationSummary' + names: + type: array + items: + type: object + required: + - language + - name + properties: + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + name: + type: string + examples: + - bulbasaur + readOnly: true + pal_park_encounters: + type: array + items: + type: object + required: + - area + - base_score + - rate + properties: + area: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - field + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pal-park-area/2/ + base_score: + type: integer + format: int32 + examples: + - 50 + rate: + type: integer + format: int32 + examples: + - 30 + readOnly: true + form_descriptions: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesDescription' + readOnly: true + flavor_text_entries: + type: array + items: + $ref: '#/components/schemas/PokemonSpeciesFlavorText' + readOnly: true + genera: + type: array + items: + type: object + required: + - genus + - language + properties: + genus: + type: string + examples: + - Seed Pokémon + language: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - en + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/language/9/ + readOnly: true + varieties: + type: array + items: + type: object + required: + - is_default + - pokemon + properties: + is_default: + type: boolean + pokemon: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bulbasaur + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokemon/1/ + readOnly: true + required: + - color + - egg_groups + - evolution_chain + - evolves_from_species + - flavor_text_entries + - form_descriptions + - genera + - generation + - growth_rate + - habitat + - id + - name + - names + - pal_park_encounters + - pokedex_numbers + - shape + - varieties + PokemonSpeciesFlavorText: + type: object + properties: + flavor_text: + type: string + language: + $ref: '#/components/schemas/LanguageSummary' + version: + $ref: '#/components/schemas/VersionSummary' + required: + - flavor_text + - language + - version + PokemonSpeciesSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + PokemonStat: + type: object + properties: + base_stat: + type: integer + effort: + type: integer + stat: + $ref: '#/components/schemas/StatSummary' + required: + - base_stat + - effort + - stat + PokemonSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + RegionDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + locations: + type: array + items: + $ref: '#/components/schemas/LocationSummary' + readOnly: true + main_generation: + allOf: + - $ref: '#/components/schemas/GenerationSummary' + readOnly: true + names: + type: array + items: + $ref: '#/components/schemas/RegionName' + readOnly: true + pokedexes: + type: array + items: + $ref: '#/components/schemas/PokedexSummary' + readOnly: true + version_groups: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - red-blue + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/version-group/1/ + readOnly: true + required: + - id + - locations + - main_generation + - name + - names + - pokedexes + - version_groups + RegionName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + RegionSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + StatDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + game_index: + type: integer + is_battle_only: + type: boolean + affecting_moves: + type: object + required: + - decrease + - increase + properties: + increase: + type: array + items: + type: object + required: + - change + - move + properties: + change: + type: integer + format: int32 + examples: + - -1 + move: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - swords-dance + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/14/ + decrease: + type: array + items: + type: object + required: + - change + - move + properties: + change: + type: integer + format: int32 + examples: + - 5 + move: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - growl + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move/45/ + readOnly: true + affecting_natures: + type: object + required: + - increase + - decrease + properties: + increase: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - lonely + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/nature/6/ + decrease: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bold + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/nature/2/ + readOnly: true + characteristics: + type: array + items: + $ref: '#/components/schemas/CharacteristicSummary' + readOnly: true + move_damage_class: + $ref: '#/components/schemas/MoveDamageClassSummary' + names: + type: array + items: + $ref: '#/components/schemas/StatName' + readOnly: true + required: + - affecting_moves + - affecting_natures + - characteristics + - game_index + - id + - move_damage_class + - name + - names + StatName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + StatSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + SuperContestEffectDetail: + type: object + properties: + id: + type: integer + readOnly: true + appeal: + type: integer + flavor_text_entries: + type: array + items: + $ref: '#/components/schemas/SuperContestEffectFlavorText' + readOnly: true + moves: + type: array + items: + $ref: '#/components/schemas/MoveSummary' + readOnly: true + required: + - appeal + - flavor_text_entries + - id + - moves + SuperContestEffectFlavorText: + type: object + properties: + flavor_text: + type: string + maxLength: 500 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - flavor_text + - language + SuperContestEffectSummary: + type: object + properties: + url: + type: string + format: uri + readOnly: true + required: + - url + TypeDetail: + type: object + description: Serializer for the Type resource + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + damage_relations: + type: object + required: + - no_damage_to + - half_damage_to + - double_damage_to + - no_damage_from + - half_damage_from + - double_damage_from + properties: + no_damage_to: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - flying + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/3/ + half_damage_to: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bug + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/7/ + double_damage_to: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - poison + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/4/ + no_damage_from: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - electric + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/13/ + half_damage_from: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - poison + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/4/ + double_damage_from: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - water + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/11/ + readOnly: true + past_damage_relations: + type: array + items: + type: object + required: + - generation + - damage_relations + properties: + generation: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - generation-v + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/generation/5/ + damage_relations: + type: object + required: + - no_damage_to + - half_damage_to + - double_damage_to + - no_damage_from + - half_damage_from + - double_damage_from + properties: + no_damage_to: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - flying + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/3/ + half_damage_to: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - bug + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/7/ + double_damage_to: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - poison + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/4/ + no_damage_from: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - electric + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/13/ + half_damage_from: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - poison + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/4/ + double_damage_from: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - water + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/type/11/ + readOnly: true + game_indices: + type: array + items: + $ref: '#/components/schemas/TypeGameIndex' + readOnly: true + generation: + $ref: '#/components/schemas/GenerationSummary' + move_damage_class: + $ref: '#/components/schemas/MoveDamageClassSummary' + names: + type: array + items: + $ref: '#/components/schemas/AbilityName' + readOnly: true + pokemon: + type: array + items: + type: object + required: + - potency + - flavor + properties: + slot: + type: integer + examples: + - 1 + pokemon: + type: object + require: + - name + - url + properties: + name: + type: string + description: The name of the pokemon + examples: + - sandshrew + url: + type: string + format: uri + description: The URL to get more information about the pokemon + examples: + - https://pokeapi.co/api/v2/pokemon/27/ + readOnly: true + moves: + type: array + items: + $ref: '#/components/schemas/MoveSummary' + readOnly: true + required: + - damage_relations + - game_indices + - generation + - id + - move_damage_class + - moves + - name + - names + - past_damage_relations + - pokemon + TypeGameIndex: + type: object + properties: + game_index: + type: integer + generation: + $ref: '#/components/schemas/GenerationSummary' + required: + - game_index + - generation + TypeSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + VersionDetail: + type: object + description: |- + Should have a link to Version Group info but the Circular + dependency and compilation order fight eachother and I'm + not sure how to add anything other than a hyperlink + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + names: + type: array + items: + $ref: '#/components/schemas/VersionName' + readOnly: true + version_group: + $ref: '#/components/schemas/VersionGroupSummary' + required: + - id + - name + - names + - version_group + VersionGroupDetail: + type: object + properties: + id: + type: integer + readOnly: true + name: + type: string + maxLength: 100 + order: + type: + - integer + - 'null' + generation: + $ref: '#/components/schemas/GenerationSummary' + move_learn_methods: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - level-up + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/move-learn-method/1/ + readOnly: true + pokedexes: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - kanto + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/pokedex/2/ + readOnly: true + regions: + type: array + items: + type: object + required: + - name + - url + properties: + name: + type: string + examples: + - kanto + url: + type: string + format: uri + examples: + - https://pokeapi.co/api/v2/region/1/ + readOnly: true + versions: + type: array + items: + $ref: '#/components/schemas/VersionSummary' + readOnly: true + required: + - generation + - id + - move_learn_methods + - name + - pokedexes + - regions + - versions + VersionGroupSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + VersionName: + type: object + properties: + name: + type: string + maxLength: 100 + language: + $ref: '#/components/schemas/LanguageSummary' + required: + - language + - name + VersionSummary: + type: object + properties: + name: + type: string + maxLength: 100 + url: + type: string + format: uri + readOnly: true + required: + - name + - url + securitySchemes: + basicAuth: + type: http + scheme: basic + cookieAuth: + type: apiKey + in: cookie + name: sessionid +servers: +- url: https://pokeapi.co +tags: +- name: pokemon + description: Pokémon are the creatures that inhabit the world of the Pokémon games. + They can be caught using Pokéballs and trained by battling with other Pokémon. + Each Pokémon belongs to a specific species but may take on a variant which makes + it differ from other Pokémon of the same species, such as base stats, available + abilities and typings. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_(species)) + for greater detail. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon +- name: evolution + description: Evolution is a process in which a Pokémon changes into a different + species of Pokémon. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/Evolution +- name: berries + description: Berries can be soft or hard. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Category:Berries_by_firmness) + for greater detail. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/Berry +- name: items + description: An item is an object in the games which the player can pick up, keep + in their bag, and use in some manner. They have various uses, including healing, + powering up, helping catch Pokémon, or to access a new area. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/Item +- name: machines + description: Machines are the representation of items that teach moves to Pokémon. + They vary from version to version, so it is not certain that one specific TM or + HM corresponds to a single Machine. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/TM +- name: location + description: Locations that can be visited within the games. Locations make up sizable + portions of regions, like cities or routes. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/List_of_locations_by_index_number +- name: contest + description: Pokémon Contests are a type of competition often contrasted with Pokémon + battles and held in Contest Halls + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_Contest +- name: moves + description: Moves are the skills of Pokémon in battle. In battle, a Pokémon uses + one move each turn. Some moves (including those learned by Hidden Machine) can + be used outside of battle as well, usually for the purpose of removing obstacles + or exploring new areas. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/List_of_locations_by_name +- name: encounters +- name: games + description: The Pokémon games are all video games in the Pokémon franchise. + externalDocs: + description: Find more info here + url: https://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_games +- name: utility +externalDocs: + url: https://pokeapi.co/docs/v2 diff --git a/webapp/src/app/app.config.ts b/webapp/src/app/app.config.ts index e68b6224..4b3c1318 100644 --- a/webapp/src/app/app.config.ts +++ b/webapp/src/app/app.config.ts @@ -1,6 +1,5 @@ import { ApplicationConfig, provideExperimentalZonelessChangeDetection } from '@angular/core'; import { provideRouter } from '@angular/router'; - import { routes } from './app.routes'; export const appConfig: ApplicationConfig = { From e4aab66aee8def90683cc7eecc61e1c72751b665 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Mon, 15 Jul 2024 10:08:34 +0200 Subject: [PATCH 06/12] init example api client --- server/{openapi.yml => openapi.yaml} | 0 webapp/openapitools.json | 7 + webapp/package-lock.json | 7 +- webapp/package.json | 5 +- .../src/app/core/modules/openapi/.gitignore | 4 + .../modules/openapi/.openapi-generator-ignore | 23 + .../modules/openapi/.openapi-generator/FILES | 308 ++ .../openapi/.openapi-generator/VERSION | 1 + webapp/src/app/core/modules/openapi/README.md | 226 ++ .../app/core/modules/openapi/api.module.ts | 30 + .../src/app/core/modules/openapi/api/api.ts | 34 + .../modules/openapi/api/berries.service.ts | 612 ++++ .../openapi/api/berries.serviceInterface.ts | 80 + .../modules/openapi/api/contests.service.ts | 612 ++++ .../openapi/api/contests.serviceInterface.ts | 80 + .../modules/openapi/api/encounters.service.ts | 691 ++++ .../api/encounters.serviceInterface.ts | 88 + .../modules/openapi/api/evolution.service.ts | 440 +++ .../openapi/api/evolution.serviceInterface.ts | 62 + .../core/modules/openapi/api/games.service.ts | 784 +++++ .../openapi/api/games.serviceInterface.ts | 98 + .../core/modules/openapi/api/items.service.ts | 956 ++++++ .../openapi/api/items.serviceInterface.ts | 116 + .../modules/openapi/api/location.service.ts | 779 +++++ .../openapi/api/location.serviceInterface.ts | 97 + .../modules/openapi/api/machines.service.ts | 268 ++ .../openapi/api/machines.serviceInterface.ts | 44 + .../core/modules/openapi/api/moves.service.ts | 1128 +++++++ .../openapi/api/moves.serviceInterface.ts | 134 + .../modules/openapi/api/pokemon.service.ts | 2846 +++++++++++++++++ .../openapi/api/pokemon.serviceInterface.ts | 314 ++ .../modules/openapi/api/utility.service.ts | 268 ++ .../openapi/api/utility.serviceInterface.ts | 44 + .../app/core/modules/openapi/configuration.ts | 186 ++ .../src/app/core/modules/openapi/encoder.ts | 20 + .../src/app/core/modules/openapi/git_push.sh | 57 + webapp/src/app/core/modules/openapi/index.ts | 6 + .../model/ability-change-effect-text.ts | 19 + .../modules/openapi/model/ability-change.ts | 20 + .../ability-detail-pokemon-inner-pokemon.ts | 18 + .../model/ability-detail-pokemon-inner.ts | 20 + .../modules/openapi/model/ability-detail.ts | 31 + .../openapi/model/ability-effect-text.ts | 20 + .../openapi/model/ability-flavor-text.ts | 21 + .../modules/openapi/model/ability-name.ts | 19 + .../modules/openapi/model/ability-summary.ts | 18 + .../berry-detail-flavors-inner-flavor.ts | 24 + .../model/berry-detail-flavors-inner.ts | 19 + .../modules/openapi/model/berry-detail.ts | 32 + .../openapi/model/berry-firmness-detail.ts | 22 + .../openapi/model/berry-firmness-name.ts | 19 + .../openapi/model/berry-firmness-summary.ts | 18 + ...berry-flavor-detail-berries-inner-berry.ts | 24 + .../berry-flavor-detail-berries-inner.ts | 19 + .../openapi/model/berry-flavor-detail.ts | 24 + .../openapi/model/berry-flavor-name.ts | 19 + .../openapi/model/berry-flavor-summary.ts | 18 + .../modules/openapi/model/berry-summary.ts | 18 + .../model/characteristic-description.ts | 19 + .../openapi/model/characteristic-detail.ts | 23 + .../openapi/model/characteristic-summary.ts | 17 + .../openapi/model/contest-effect-detail.ts | 23 + .../model/contest-effect-effect-text.ts | 19 + .../model/contest-effect-flavor-text.ts | 19 + .../openapi/model/contest-effect-summary.ts | 17 + .../openapi/model/contest-type-detail.ts | 22 + .../openapi/model/contest-type-name.ts | 20 + .../openapi/model/contest-type-summary.ts | 18 + .../egg-group-detail-pokemon-species-inner.ts | 24 + .../modules/openapi/model/egg-group-detail.ts | 22 + .../modules/openapi/model/egg-group-name.ts | 19 + .../openapi/model/egg-group-summary.ts | 18 + .../model/encounter-condition-detail.ts | 22 + .../openapi/model/encounter-condition-name.ts | 19 + .../model/encounter-condition-summary.ts | 18 + .../model/encounter-condition-value-detail.ts | 22 + .../model/encounter-condition-value-name.ts | 19 + .../encounter-condition-value-summary.ts | 18 + .../openapi/model/encounter-method-detail.ts | 21 + .../openapi/model/encounter-method-name.ts | 19 + .../openapi/model/encounter-method-summary.ts | 18 + ...to-inner-evolution-details-inner-gender.ts | 18 + ...volves-to-inner-evolution-details-inner.ts | 36 + ...ion-chain-detail-chain-evolves-to-inner.ts | 21 + .../model/evolution-chain-detail-chain.ts | 22 + .../openapi/model/evolution-chain-detail.ts | 21 + .../openapi/model/evolution-chain-summary.ts | 17 + .../openapi/model/evolution-trigger-detail.ts | 22 + .../openapi/model/evolution-trigger-name.ts | 19 + .../model/evolution-trigger-summary.ts | 18 + .../core/modules/openapi/model/experience.ts | 18 + ...er-detail-pokemon-species-details-inner.ts | 19 + .../modules/openapi/model/gender-detail.ts | 22 + .../modules/openapi/model/gender-summary.ts | 18 + .../openapi/model/generation-detail.ts | 32 + .../modules/openapi/model/generation-name.ts | 19 + .../openapi/model/generation-summary.ts | 18 + .../openapi/model/growth-rate-description.ts | 19 + .../openapi/model/growth-rate-detail.ts | 25 + .../openapi/model/growth-rate-summary.ts | 18 + .../model/item-attribute-description.ts | 19 + .../openapi/model/item-attribute-detail.ts | 24 + .../openapi/model/item-attribute-name.ts | 19 + .../openapi/model/item-attribute-summary.ts | 18 + .../openapi/model/item-category-detail.ts | 24 + .../openapi/model/item-category-name.ts | 19 + .../openapi/model/item-category-summary.ts | 18 + .../model/item-detail-baby-trigger-for.ts | 17 + ...-by-pokemon-inner-version-details-inner.ts | 19 + .../item-detail-held-by-pokemon-inner.ts | 20 + .../model/item-detail-machines-inner.ts | 19 + .../openapi/model/item-detail-sprites.ts | 17 + .../core/modules/openapi/model/item-detail.ts | 42 + .../modules/openapi/model/item-effect-text.ts | 20 + .../modules/openapi/model/item-flavor-text.ts | 21 + .../openapi/model/item-fling-effect-detail.ts | 22 + .../model/item-fling-effect-effect-text.ts | 19 + .../model/item-fling-effect-summary.ts | 18 + .../modules/openapi/model/item-game-index.ts | 19 + .../core/modules/openapi/model/item-name.ts | 19 + .../openapi/model/item-pocket-detail.ts | 22 + .../modules/openapi/model/item-pocket-name.ts | 19 + .../openapi/model/item-pocket-summary.ts | 18 + .../modules/openapi/model/item-summary.ts | 18 + .../modules/openapi/model/language-detail.ts | 23 + .../modules/openapi/model/language-name.ts | 19 + .../modules/openapi/model/language-summary.ts | 18 + ...ethod-rates-inner-version-details-inner.ts | 19 + ...rea-detail-encounter-method-rates-inner.ts | 20 + ...version-details-inner-encounter-details.ts | 22 + ...-encounters-inner-version-details-inner.ts | 21 + ...on-area-detail-pokemon-encounters-inner.ts | 20 + .../openapi/model/location-area-detail.ts | 27 + .../openapi/model/location-area-name.ts | 19 + .../openapi/model/location-area-summary.ts | 18 + .../modules/openapi/model/location-detail.ts | 26 + .../openapi/model/location-game-index.ts | 19 + .../modules/openapi/model/location-name.ts | 19 + .../modules/openapi/model/location-summary.ts | 18 + .../modules/openapi/model/machine-detail.ts | 23 + .../modules/openapi/model/machine-summary.ts | 17 + .../app/core/modules/openapi/model/models.ts | 274 ++ .../openapi/model/move-battle-style-detail.ts | 20 + .../openapi/model/move-battle-style-name.ts | 19 + .../model/move-battle-style-summary.ts | 18 + .../model/move-change-effect-entries-inner.ts | 20 + .../core/modules/openapi/model/move-change.ts | 26 + .../model/move-damage-class-description.ts | 19 + .../openapi/model/move-damage-class-detail.ts | 24 + .../openapi/model/move-damage-class-name.ts | 19 + .../model/move-damage-class-summary.ts | 18 + .../move-detail-contest-combos-normal.ts | 19 + .../model/move-detail-contest-combos.ts | 19 + ...fect-changes-inner-effect-entries-inner.ts | 19 + .../model/move-detail-effect-changes-inner.ts | 20 + .../move-detail-machines-inner-machine.ts | 17 + .../model/move-detail-machines-inner.ts | 20 + .../model/move-detail-stat-changes-inner.ts | 19 + .../core/modules/openapi/model/move-detail.ts | 57 + .../modules/openapi/model/move-flavor-text.ts | 21 + .../model/move-learn-method-description.ts | 19 + .../openapi/model/move-learn-method-detail.ts | 24 + .../openapi/model/move-learn-method-name.ts | 19 + .../model/move-learn-method-summary.ts | 18 + .../openapi/model/move-meta-ailment-detail.ts | 22 + .../openapi/model/move-meta-ailment-name.ts | 19 + .../model/move-meta-ailment-summary.ts | 18 + .../model/move-meta-category-description.ts | 19 + .../model/move-meta-category-detail.ts | 22 + .../model/move-meta-category-summary.ts | 18 + .../core/modules/openapi/model/move-meta.ts | 30 + .../core/modules/openapi/model/move-name.ts | 19 + .../modules/openapi/model/move-summary.ts | 18 + .../openapi/model/move-target-description.ts | 19 + .../openapi/model/move-target-detail.ts | 24 + .../modules/openapi/model/move-target-name.ts | 19 + .../openapi/model/move-target-summary.ts | 18 + .../model/nature-battle-style-preference.ts | 20 + ...re-detail-pokeathlon-stat-changes-inner.ts | 19 + .../modules/openapi/model/nature-detail.ts | 32 + .../core/modules/openapi/model/nature-name.ts | 19 + .../modules/openapi/model/nature-summary.ts | 18 + .../model/paginated-ability-summary-list.ts | 21 + .../paginated-berry-firmness-summary-list.ts | 21 + .../paginated-berry-flavor-summary-list.ts | 21 + .../model/paginated-berry-summary-list.ts | 21 + .../paginated-characteristic-summary-list.ts | 21 + .../paginated-contest-effect-summary-list.ts | 21 + .../paginated-contest-type-summary-list.ts | 21 + .../model/paginated-egg-group-summary-list.ts | 21 + ...inated-encounter-condition-summary-list.ts | 21 + ...-encounter-condition-value-summary-list.ts | 21 + ...paginated-encounter-method-summary-list.ts | 21 + .../paginated-evolution-chain-summary-list.ts | 21 + ...aginated-evolution-trigger-summary-list.ts | 21 + .../model/paginated-gender-summary-list.ts | 21 + .../paginated-generation-summary-list.ts | 21 + .../paginated-growth-rate-summary-list.ts | 21 + .../paginated-item-attribute-summary-list.ts | 21 + .../paginated-item-category-summary-list.ts | 21 + ...aginated-item-fling-effect-summary-list.ts | 21 + .../paginated-item-pocket-summary-list.ts | 21 + .../model/paginated-item-summary-list.ts | 21 + .../model/paginated-language-summary-list.ts | 21 + .../paginated-location-area-summary-list.ts | 21 + .../model/paginated-location-summary-list.ts | 21 + .../model/paginated-machine-summary-list.ts | 21 + ...aginated-move-battle-style-summary-list.ts | 21 + ...aginated-move-damage-class-summary-list.ts | 21 + ...aginated-move-learn-method-summary-list.ts | 21 + ...aginated-move-meta-ailment-summary-list.ts | 21 + ...ginated-move-meta-category-summary-list.ts | 21 + .../model/paginated-move-summary-list.ts | 21 + .../paginated-move-target-summary-list.ts | 21 + .../model/paginated-nature-summary-list.ts | 21 + .../paginated-pal-park-area-summary-list.ts | 21 + .../paginated-pokeathlon-stat-summary-list.ts | 21 + .../model/paginated-pokedex-summary-list.ts | 21 + .../paginated-pokemon-color-summary-list.ts | 21 + .../paginated-pokemon-form-summary-list.ts | 21 + .../paginated-pokemon-habitat-summary-list.ts | 21 + .../paginated-pokemon-shape-summary-list.ts | 21 + .../paginated-pokemon-species-summary-list.ts | 21 + .../model/paginated-pokemon-summary-list.ts | 21 + .../model/paginated-region-summary-list.ts | 21 + .../model/paginated-stat-summary-list.ts | 21 + ...nated-super-contest-effect-summary-list.ts | 21 + .../model/paginated-type-summary-list.ts | 21 + .../paginated-version-group-summary-list.ts | 21 + .../model/paginated-version-summary-list.ts | 21 + ...rk-area-detail-pokemon-encounters-inner.ts | 20 + .../openapi/model/pal-park-area-detail.ts | 22 + .../openapi/model/pal-park-area-name.ts | 19 + .../openapi/model/pal-park-area-summary.ts | 18 + ...detail-affecting-natures-decrease-inner.ts | 19 + ...detail-affecting-natures-increase-inner.ts | 19 + ...okeathlon-stat-detail-affecting-natures.ts | 20 + .../openapi/model/pokeathlon-stat-detail.ts | 22 + .../openapi/model/pokeathlon-stat-name.ts | 19 + .../openapi/model/pokeathlon-stat-summary.ts | 18 + .../openapi/model/pokedex-description.ts | 19 + .../pokedex-detail-pokemon-entries-inner.ts | 19 + .../modules/openapi/model/pokedex-detail.ts | 29 + .../modules/openapi/model/pokedex-name.ts | 19 + .../modules/openapi/model/pokedex-summary.ts | 18 + .../openapi/model/pokemon-color-detail.ts | 22 + .../openapi/model/pokemon-color-name.ts | 19 + .../openapi/model/pokemon-color-summary.ts | 18 + .../model/pokemon-detail-abilities-inner.ts | 20 + .../openapi/model/pokemon-detail-cries.ts | 18 + .../model/pokemon-detail-held-items.ts | 20 + ...moves-inner-version-group-details-inner.ts | 20 + .../model/pokemon-detail-moves-inner.ts | 20 + .../pokemon-detail-past-abilities-inner.ts | 20 + .../model/pokemon-detail-past-types-inner.ts | 20 + .../openapi/model/pokemon-detail-sprites.ts | 20 + .../model/pokemon-detail-types-inner.ts | 19 + .../modules/openapi/model/pokemon-detail.ts | 48 + .../openapi/model/pokemon-dex-entry.ts | 19 + ...etrieve200-response-inner-location-area.ts | 18 + ...er-details-inner-condition-values-inner.ts | 18 + ...ls-inner-encounter-details-inner-method.ts | 18 + ...n-details-inner-encounter-details-inner.ts | 23 + ...nse-inner-version-details-inner-version.ts | 18 + ...00-response-inner-version-details-inner.ts | 21 + ...n-encounters-retrieve200-response-inner.ts | 20 + .../pokemon-form-detail-form-names-inner.ts | 19 + .../model/pokemon-form-detail-sprites.ts | 20 + .../openapi/model/pokemon-form-detail.ts | 35 + .../openapi/model/pokemon-form-summary.ts | 18 + .../openapi/model/pokemon-game-index.ts | 19 + .../openapi/model/pokemon-habitat-detail.ts | 22 + .../openapi/model/pokemon-habitat-name.ts | 19 + .../openapi/model/pokemon-habitat-summary.ts | 18 + ...okemon-shape-detail-awesome-names-inner.ts | 19 + .../model/pokemon-shape-detail-names-inner.ts | 18 + .../openapi/model/pokemon-shape-detail.ts | 24 + .../openapi/model/pokemon-shape-summary.ts | 18 + .../model/pokemon-species-description.ts | 19 + .../pokemon-species-detail-genera-inner.ts | 19 + ...pecies-detail-pal-park-encounters-inner.ts | 20 + .../pokemon-species-detail-varieties-inner.ts | 19 + .../openapi/model/pokemon-species-detail.ts | 58 + .../model/pokemon-species-flavor-text.ts | 21 + .../openapi/model/pokemon-species-summary.ts | 18 + .../modules/openapi/model/pokemon-stat.ts | 20 + .../modules/openapi/model/pokemon-summary.ts | 18 + .../modules/openapi/model/region-detail.ts | 28 + .../core/modules/openapi/model/region-name.ts | 19 + .../modules/openapi/model/region-summary.ts | 18 + ...t-detail-affecting-moves-increase-inner.ts | 19 + .../model/stat-detail-affecting-moves.ts | 19 + .../model/stat-detail-affecting-natures.ts | 19 + .../core/modules/openapi/model/stat-detail.ts | 30 + .../core/modules/openapi/model/stat-name.ts | 19 + .../modules/openapi/model/stat-summary.ts | 18 + .../model/super-contest-effect-detail.ts | 22 + .../model/super-contest-effect-flavor-text.ts | 19 + .../model/super-contest-effect-summary.ts | 17 + .../model/type-detail-damage-relations.ts | 23 + ...damage-relations-inner-damage-relations.ts | 23 + ...type-detail-past-damage-relations-inner.ts | 20 + .../type-detail-pokemon-inner-pokemon.ts | 24 + .../model/type-detail-pokemon-inner.ts | 19 + .../core/modules/openapi/model/type-detail.ts | 37 + .../modules/openapi/model/type-game-index.ts | 19 + .../modules/openapi/model/type-summary.ts | 18 + .../modules/openapi/model/version-detail.ts | 25 + .../openapi/model/version-group-detail.ts | 27 + .../openapi/model/version-group-summary.ts | 18 + .../modules/openapi/model/version-name.ts | 19 + .../modules/openapi/model/version-summary.ts | 18 + webapp/src/app/core/modules/openapi/param.ts | 69 + .../src/app/core/modules/openapi/variables.ts | 9 + 314 files changed, 17532 insertions(+), 5 deletions(-) rename server/{openapi.yml => openapi.yaml} (100%) create mode 100644 webapp/openapitools.json create mode 100644 webapp/src/app/core/modules/openapi/.gitignore create mode 100644 webapp/src/app/core/modules/openapi/.openapi-generator-ignore create mode 100644 webapp/src/app/core/modules/openapi/.openapi-generator/FILES create mode 100644 webapp/src/app/core/modules/openapi/.openapi-generator/VERSION create mode 100644 webapp/src/app/core/modules/openapi/README.md create mode 100644 webapp/src/app/core/modules/openapi/api.module.ts create mode 100644 webapp/src/app/core/modules/openapi/api/api.ts create mode 100644 webapp/src/app/core/modules/openapi/api/berries.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/berries.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/contests.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/contests.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/encounters.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/encounters.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/evolution.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/evolution.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/games.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/games.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/items.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/items.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/location.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/location.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/machines.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/machines.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/moves.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/moves.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/pokemon.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/pokemon.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/api/utility.service.ts create mode 100644 webapp/src/app/core/modules/openapi/api/utility.serviceInterface.ts create mode 100644 webapp/src/app/core/modules/openapi/configuration.ts create mode 100644 webapp/src/app/core/modules/openapi/encoder.ts create mode 100644 webapp/src/app/core/modules/openapi/git_push.sh create mode 100644 webapp/src/app/core/modules/openapi/index.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-change-effect-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-change.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner-pokemon.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-effect-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-flavor-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/ability-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner-flavor.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-firmness-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-firmness-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-firmness-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner-berry.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-flavor-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-flavor-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-flavor-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/berry-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/characteristic-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/characteristic-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/characteristic-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/contest-effect-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/contest-effect-effect-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/contest-effect-flavor-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/contest-effect-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/contest-type-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/contest-type-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/contest-type-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/egg-group-detail-pokemon-species-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/egg-group-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/egg-group-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/egg-group-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-condition-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-condition-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-condition-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-condition-value-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-condition-value-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-condition-value-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-method-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-method-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/encounter-method-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner-gender.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-chain-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-chain-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-trigger-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-trigger-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/evolution-trigger-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/experience.ts create mode 100644 webapp/src/app/core/modules/openapi/model/gender-detail-pokemon-species-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/gender-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/gender-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/generation-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/generation-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/generation-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/growth-rate-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/growth-rate-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/growth-rate-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-attribute-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-attribute-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-attribute-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-attribute-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-category-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-category-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-category-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-detail-baby-trigger-for.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner-version-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-detail-machines-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-detail-sprites.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-effect-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-flavor-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-fling-effect-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-fling-effect-effect-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-fling-effect-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-game-index.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-pocket-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-pocket-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-pocket-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/item-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/language-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/language-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/language-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner-version-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner-encounter-details.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-area-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-game-index.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/location-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/machine-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/machine-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/models.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-battle-style-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-battle-style-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-battle-style-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-change-effect-entries-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-change.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-damage-class-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-damage-class-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-damage-class-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-damage-class-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail-contest-combos-normal.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail-contest-combos.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner-effect-entries-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail-machines-inner-machine.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail-machines-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail-stat-changes-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-flavor-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-learn-method-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-learn-method-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-learn-method-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-learn-method-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-meta-ailment-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-meta-ailment-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-meta-ailment-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-meta-category-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-meta-category-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-meta-category-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-meta.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-target-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-target-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-target-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/move-target-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/nature-battle-style-preference.ts create mode 100644 webapp/src/app/core/modules/openapi/model/nature-detail-pokeathlon-stat-changes-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/nature-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/nature-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/nature-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-ability-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-berry-firmness-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-berry-flavor-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-berry-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-characteristic-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-contest-effect-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-contest-type-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-egg-group-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-value-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-encounter-method-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-evolution-chain-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-evolution-trigger-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-gender-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-generation-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-growth-rate-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-item-attribute-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-item-category-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-item-fling-effect-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-item-pocket-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-item-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-language-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-location-area-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-location-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-machine-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-move-battle-style-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-move-damage-class-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-move-learn-method-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-move-meta-ailment-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-move-meta-category-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-move-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-move-target-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-nature-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pal-park-area-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokeathlon-stat-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokedex-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokemon-color-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokemon-form-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokemon-habitat-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokemon-shape-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokemon-species-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-pokemon-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-region-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-stat-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-super-contest-effect-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-type-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-version-group-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/paginated-version-summary-list.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pal-park-area-detail-pokemon-encounters-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pal-park-area-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pal-park-area-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pal-park-area-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-decrease-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-increase-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokeathlon-stat-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokeathlon-stat-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokedex-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokedex-detail-pokemon-entries-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokedex-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokedex-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokedex-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-color-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-color-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-color-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-abilities-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-cries.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-held-items.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner-version-group-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-past-abilities-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-past-types-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-sprites.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail-types-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-dex-entry.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-location-area.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-condition-values-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-method.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-version.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-form-detail-form-names-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-form-detail-sprites.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-form-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-form-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-game-index.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-habitat-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-habitat-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-habitat-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-awesome-names-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-names-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-shape-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-shape-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-species-description.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-species-detail-genera-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-species-detail-pal-park-encounters-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-species-detail-varieties-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-species-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-species-flavor-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-species-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-stat.ts create mode 100644 webapp/src/app/core/modules/openapi/model/pokemon-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/region-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/region-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/region-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves-increase-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves.ts create mode 100644 webapp/src/app/core/modules/openapi/model/stat-detail-affecting-natures.ts create mode 100644 webapp/src/app/core/modules/openapi/model/stat-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/stat-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/stat-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/super-contest-effect-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/super-contest-effect-flavor-text.ts create mode 100644 webapp/src/app/core/modules/openapi/model/super-contest-effect-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-detail-damage-relations.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner-damage-relations.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner-pokemon.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-game-index.ts create mode 100644 webapp/src/app/core/modules/openapi/model/type-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/version-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/version-group-detail.ts create mode 100644 webapp/src/app/core/modules/openapi/model/version-group-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/model/version-name.ts create mode 100644 webapp/src/app/core/modules/openapi/model/version-summary.ts create mode 100644 webapp/src/app/core/modules/openapi/param.ts create mode 100644 webapp/src/app/core/modules/openapi/variables.ts diff --git a/server/openapi.yml b/server/openapi.yaml similarity index 100% rename from server/openapi.yml rename to server/openapi.yaml diff --git a/webapp/openapitools.json b/webapp/openapitools.json new file mode 100644 index 00000000..f227cf2d --- /dev/null +++ b/webapp/openapitools.json @@ -0,0 +1,7 @@ +{ + "$schema": "./node_modules/@openapitools/openapi-generator-cli/config.schema.json", + "spaces": 2, + "generator-cli": { + "version": "7.7.0" + } +} diff --git a/webapp/package-lock.json b/webapp/package-lock.json index 0b513fdf..de6fb0c2 100644 --- a/webapp/package-lock.json +++ b/webapp/package-lock.json @@ -1,11 +1,11 @@ { - "name": "webapp", + "name": "hephaestus", "version": "0.0.0", "lockfileVersion": 3, "requires": true, "packages": { "": { - "name": "webapp", + "name": "hephaestus", "version": "0.0.0", "dependencies": { "@angular/animations": "18.1.0", @@ -12630,7 +12630,8 @@ "node_modules/zone.js": { "version": "0.14.7", "resolved": "https://registry.npmjs.org/zone.js/-/zone.js-0.14.7.tgz", - "integrity": "sha512-0w6DGkX2BPuiK/NLf+4A8FLE43QwBfuqz2dVgi/40Rj1WmqUskCqj329O/pwrqFJLG5X8wkeG2RhIAro441xtg==" + "integrity": "sha512-0w6DGkX2BPuiK/NLf+4A8FLE43QwBfuqz2dVgi/40Rj1WmqUskCqj329O/pwrqFJLG5X8wkeG2RhIAro441xtg==", + "peer": true } } } diff --git a/webapp/package.json b/webapp/package.json index 14800cc4..f38758b4 100644 --- a/webapp/package.json +++ b/webapp/package.json @@ -1,12 +1,13 @@ { - "name": "webapp", + "name": "hephaestus", "version": "0.0.0", "scripts": { "ng": "ng", "start": "ng serve", "build": "ng build", "watch": "ng build --watch --configuration development", - "test": "ng test" + "test": "ng test", + "generate:api": "npx openapi-generator-cli generate -i ../server/openapi.yaml -g typescript-angular -o ./src/app/core/modules/openapi --additional-properties fileNaming=kebab-case,withInterfaces=true --generate-alias-as-model" }, "private": true, "dependencies": { diff --git a/webapp/src/app/core/modules/openapi/.gitignore b/webapp/src/app/core/modules/openapi/.gitignore new file mode 100644 index 00000000..149b5765 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/.gitignore @@ -0,0 +1,4 @@ +wwwroot/*.js +node_modules +typings +dist diff --git a/webapp/src/app/core/modules/openapi/.openapi-generator-ignore b/webapp/src/app/core/modules/openapi/.openapi-generator-ignore new file mode 100644 index 00000000..7484ee59 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/.openapi-generator-ignore @@ -0,0 +1,23 @@ +# OpenAPI Generator Ignore +# Generated by openapi-generator https://github.com/openapitools/openapi-generator + +# Use this file to prevent files from being overwritten by the generator. +# The patterns follow closely to .gitignore or .dockerignore. + +# As an example, the C# client generator defines ApiClient.cs. +# You can make changes and tell OpenAPI Generator to ignore just this file by uncommenting the following line: +#ApiClient.cs + +# You can match any string of characters against a directory, file or extension with a single asterisk (*): +#foo/*/qux +# The above matches foo/bar/qux and foo/baz/qux, but not foo/bar/baz/qux + +# You can recursively match patterns against a directory, file or extension with a double asterisk (**): +#foo/**/qux +# This matches foo/bar/qux, foo/baz/qux, and foo/bar/baz/qux + +# You can also negate patterns with an exclamation (!). +# For example, you can ignore all files in a docs folder with the file extension .md: +#docs/*.md +# Then explicitly reverse the ignore rule for a single file: +#!docs/README.md diff --git a/webapp/src/app/core/modules/openapi/.openapi-generator/FILES b/webapp/src/app/core/modules/openapi/.openapi-generator/FILES new file mode 100644 index 00000000..7846626f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/.openapi-generator/FILES @@ -0,0 +1,308 @@ +.gitignore +.openapi-generator-ignore +README.md +api.module.ts +api/api.ts +api/berries.service.ts +api/berries.serviceInterface.ts +api/contests.service.ts +api/contests.serviceInterface.ts +api/encounters.service.ts +api/encounters.serviceInterface.ts +api/evolution.service.ts +api/evolution.serviceInterface.ts +api/games.service.ts +api/games.serviceInterface.ts +api/items.service.ts +api/items.serviceInterface.ts +api/location.service.ts +api/location.serviceInterface.ts +api/machines.service.ts +api/machines.serviceInterface.ts +api/moves.service.ts +api/moves.serviceInterface.ts +api/pokemon.service.ts +api/pokemon.serviceInterface.ts +api/utility.service.ts +api/utility.serviceInterface.ts +configuration.ts +encoder.ts +git_push.sh +index.ts +model/ability-change-effect-text.ts +model/ability-change.ts +model/ability-detail-pokemon-inner-pokemon.ts +model/ability-detail-pokemon-inner.ts +model/ability-detail.ts +model/ability-effect-text.ts +model/ability-flavor-text.ts +model/ability-name.ts +model/ability-summary.ts +model/berry-detail-flavors-inner-flavor.ts +model/berry-detail-flavors-inner.ts +model/berry-detail.ts +model/berry-firmness-detail.ts +model/berry-firmness-name.ts +model/berry-firmness-summary.ts +model/berry-flavor-detail-berries-inner-berry.ts +model/berry-flavor-detail-berries-inner.ts +model/berry-flavor-detail.ts +model/berry-flavor-name.ts +model/berry-flavor-summary.ts +model/berry-summary.ts +model/characteristic-description.ts +model/characteristic-detail.ts +model/characteristic-summary.ts +model/contest-effect-detail.ts +model/contest-effect-effect-text.ts +model/contest-effect-flavor-text.ts +model/contest-effect-summary.ts +model/contest-type-detail.ts +model/contest-type-name.ts +model/contest-type-summary.ts +model/egg-group-detail-pokemon-species-inner.ts +model/egg-group-detail.ts +model/egg-group-name.ts +model/egg-group-summary.ts +model/encounter-condition-detail.ts +model/encounter-condition-name.ts +model/encounter-condition-summary.ts +model/encounter-condition-value-detail.ts +model/encounter-condition-value-name.ts +model/encounter-condition-value-summary.ts +model/encounter-method-detail.ts +model/encounter-method-name.ts +model/encounter-method-summary.ts +model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner-gender.ts +model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner.ts +model/evolution-chain-detail-chain-evolves-to-inner.ts +model/evolution-chain-detail-chain.ts +model/evolution-chain-detail.ts +model/evolution-chain-summary.ts +model/evolution-trigger-detail.ts +model/evolution-trigger-name.ts +model/evolution-trigger-summary.ts +model/experience.ts +model/gender-detail-pokemon-species-details-inner.ts +model/gender-detail.ts +model/gender-summary.ts +model/generation-detail.ts +model/generation-name.ts +model/generation-summary.ts +model/growth-rate-description.ts +model/growth-rate-detail.ts +model/growth-rate-summary.ts +model/item-attribute-description.ts +model/item-attribute-detail.ts +model/item-attribute-name.ts +model/item-attribute-summary.ts +model/item-category-detail.ts +model/item-category-name.ts +model/item-category-summary.ts +model/item-detail-baby-trigger-for.ts +model/item-detail-held-by-pokemon-inner-version-details-inner.ts +model/item-detail-held-by-pokemon-inner.ts +model/item-detail-machines-inner.ts +model/item-detail-sprites.ts +model/item-detail.ts +model/item-effect-text.ts +model/item-flavor-text.ts +model/item-fling-effect-detail.ts +model/item-fling-effect-effect-text.ts +model/item-fling-effect-summary.ts +model/item-game-index.ts +model/item-name.ts +model/item-pocket-detail.ts +model/item-pocket-name.ts +model/item-pocket-summary.ts +model/item-summary.ts +model/language-detail.ts +model/language-name.ts +model/language-summary.ts +model/location-area-detail-encounter-method-rates-inner-version-details-inner.ts +model/location-area-detail-encounter-method-rates-inner.ts +model/location-area-detail-pokemon-encounters-inner-version-details-inner-encounter-details.ts +model/location-area-detail-pokemon-encounters-inner-version-details-inner.ts +model/location-area-detail-pokemon-encounters-inner.ts +model/location-area-detail.ts +model/location-area-name.ts +model/location-area-summary.ts +model/location-detail.ts +model/location-game-index.ts +model/location-name.ts +model/location-summary.ts +model/machine-detail.ts +model/machine-summary.ts +model/models.ts +model/move-battle-style-detail.ts +model/move-battle-style-name.ts +model/move-battle-style-summary.ts +model/move-change-effect-entries-inner.ts +model/move-change.ts +model/move-damage-class-description.ts +model/move-damage-class-detail.ts +model/move-damage-class-name.ts +model/move-damage-class-summary.ts +model/move-detail-contest-combos-normal.ts +model/move-detail-contest-combos.ts +model/move-detail-effect-changes-inner-effect-entries-inner.ts +model/move-detail-effect-changes-inner.ts +model/move-detail-machines-inner-machine.ts +model/move-detail-machines-inner.ts +model/move-detail-stat-changes-inner.ts +model/move-detail.ts +model/move-flavor-text.ts +model/move-learn-method-description.ts +model/move-learn-method-detail.ts +model/move-learn-method-name.ts +model/move-learn-method-summary.ts +model/move-meta-ailment-detail.ts +model/move-meta-ailment-name.ts +model/move-meta-ailment-summary.ts +model/move-meta-category-description.ts +model/move-meta-category-detail.ts +model/move-meta-category-summary.ts +model/move-meta.ts +model/move-name.ts +model/move-summary.ts +model/move-target-description.ts +model/move-target-detail.ts +model/move-target-name.ts +model/move-target-summary.ts +model/nature-battle-style-preference.ts +model/nature-detail-pokeathlon-stat-changes-inner.ts +model/nature-detail.ts +model/nature-name.ts +model/nature-summary.ts +model/paginated-ability-summary-list.ts +model/paginated-berry-firmness-summary-list.ts +model/paginated-berry-flavor-summary-list.ts +model/paginated-berry-summary-list.ts +model/paginated-characteristic-summary-list.ts +model/paginated-contest-effect-summary-list.ts +model/paginated-contest-type-summary-list.ts +model/paginated-egg-group-summary-list.ts +model/paginated-encounter-condition-summary-list.ts +model/paginated-encounter-condition-value-summary-list.ts +model/paginated-encounter-method-summary-list.ts +model/paginated-evolution-chain-summary-list.ts +model/paginated-evolution-trigger-summary-list.ts +model/paginated-gender-summary-list.ts +model/paginated-generation-summary-list.ts +model/paginated-growth-rate-summary-list.ts +model/paginated-item-attribute-summary-list.ts +model/paginated-item-category-summary-list.ts +model/paginated-item-fling-effect-summary-list.ts +model/paginated-item-pocket-summary-list.ts +model/paginated-item-summary-list.ts +model/paginated-language-summary-list.ts +model/paginated-location-area-summary-list.ts +model/paginated-location-summary-list.ts +model/paginated-machine-summary-list.ts +model/paginated-move-battle-style-summary-list.ts +model/paginated-move-damage-class-summary-list.ts +model/paginated-move-learn-method-summary-list.ts +model/paginated-move-meta-ailment-summary-list.ts +model/paginated-move-meta-category-summary-list.ts +model/paginated-move-summary-list.ts +model/paginated-move-target-summary-list.ts +model/paginated-nature-summary-list.ts +model/paginated-pal-park-area-summary-list.ts +model/paginated-pokeathlon-stat-summary-list.ts +model/paginated-pokedex-summary-list.ts +model/paginated-pokemon-color-summary-list.ts +model/paginated-pokemon-form-summary-list.ts +model/paginated-pokemon-habitat-summary-list.ts +model/paginated-pokemon-shape-summary-list.ts +model/paginated-pokemon-species-summary-list.ts +model/paginated-pokemon-summary-list.ts +model/paginated-region-summary-list.ts +model/paginated-stat-summary-list.ts +model/paginated-super-contest-effect-summary-list.ts +model/paginated-type-summary-list.ts +model/paginated-version-group-summary-list.ts +model/paginated-version-summary-list.ts +model/pal-park-area-detail-pokemon-encounters-inner.ts +model/pal-park-area-detail.ts +model/pal-park-area-name.ts +model/pal-park-area-summary.ts +model/pokeathlon-stat-detail-affecting-natures-decrease-inner.ts +model/pokeathlon-stat-detail-affecting-natures-increase-inner.ts +model/pokeathlon-stat-detail-affecting-natures.ts +model/pokeathlon-stat-detail.ts +model/pokeathlon-stat-name.ts +model/pokeathlon-stat-summary.ts +model/pokedex-description.ts +model/pokedex-detail-pokemon-entries-inner.ts +model/pokedex-detail.ts +model/pokedex-name.ts +model/pokedex-summary.ts +model/pokemon-color-detail.ts +model/pokemon-color-name.ts +model/pokemon-color-summary.ts +model/pokemon-detail-abilities-inner.ts +model/pokemon-detail-cries.ts +model/pokemon-detail-held-items.ts +model/pokemon-detail-moves-inner-version-group-details-inner.ts +model/pokemon-detail-moves-inner.ts +model/pokemon-detail-past-abilities-inner.ts +model/pokemon-detail-past-types-inner.ts +model/pokemon-detail-sprites.ts +model/pokemon-detail-types-inner.ts +model/pokemon-detail.ts +model/pokemon-dex-entry.ts +model/pokemon-encounters-retrieve200-response-inner-location-area.ts +model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-condition-values-inner.ts +model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-method.ts +model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner.ts +model/pokemon-encounters-retrieve200-response-inner-version-details-inner-version.ts +model/pokemon-encounters-retrieve200-response-inner-version-details-inner.ts +model/pokemon-encounters-retrieve200-response-inner.ts +model/pokemon-form-detail-form-names-inner.ts +model/pokemon-form-detail-sprites.ts +model/pokemon-form-detail.ts +model/pokemon-form-summary.ts +model/pokemon-game-index.ts +model/pokemon-habitat-detail.ts +model/pokemon-habitat-name.ts +model/pokemon-habitat-summary.ts +model/pokemon-shape-detail-awesome-names-inner.ts +model/pokemon-shape-detail-names-inner.ts +model/pokemon-shape-detail.ts +model/pokemon-shape-summary.ts +model/pokemon-species-description.ts +model/pokemon-species-detail-genera-inner.ts +model/pokemon-species-detail-pal-park-encounters-inner.ts +model/pokemon-species-detail-varieties-inner.ts +model/pokemon-species-detail.ts +model/pokemon-species-flavor-text.ts +model/pokemon-species-summary.ts +model/pokemon-stat.ts +model/pokemon-summary.ts +model/region-detail.ts +model/region-name.ts +model/region-summary.ts +model/stat-detail-affecting-moves-increase-inner.ts +model/stat-detail-affecting-moves.ts +model/stat-detail-affecting-natures.ts +model/stat-detail.ts +model/stat-name.ts +model/stat-summary.ts +model/super-contest-effect-detail.ts +model/super-contest-effect-flavor-text.ts +model/super-contest-effect-summary.ts +model/type-detail-damage-relations.ts +model/type-detail-past-damage-relations-inner-damage-relations.ts +model/type-detail-past-damage-relations-inner.ts +model/type-detail-pokemon-inner-pokemon.ts +model/type-detail-pokemon-inner.ts +model/type-detail.ts +model/type-game-index.ts +model/type-summary.ts +model/version-detail.ts +model/version-group-detail.ts +model/version-group-summary.ts +model/version-name.ts +model/version-summary.ts +param.ts +variables.ts diff --git a/webapp/src/app/core/modules/openapi/.openapi-generator/VERSION b/webapp/src/app/core/modules/openapi/.openapi-generator/VERSION new file mode 100644 index 00000000..1985849f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/.openapi-generator/VERSION @@ -0,0 +1 @@ +7.7.0 diff --git a/webapp/src/app/core/modules/openapi/README.md b/webapp/src/app/core/modules/openapi/README.md new file mode 100644 index 00000000..de16f95a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/README.md @@ -0,0 +1,226 @@ +## @ + +### Building + +To install the required dependencies and to build the typescript sources run: +``` +npm install +npm run build +``` + +### publishing + +First build the package then run ```npm publish dist``` (don't forget to specify the `dist` folder!) + +### consuming + +Navigate to the folder of your consuming project and run one of next commands. + +_published:_ + +``` +npm install @ --save +``` + +_without publishing (not recommended):_ + +``` +npm install PATH_TO_GENERATED_PACKAGE/dist.tgz --save +``` + +_It's important to take the tgz file, otherwise you'll get trouble with links on windows_ + +_using `npm link`:_ + +In PATH_TO_GENERATED_PACKAGE/dist: +``` +npm link +``` + +In your project: +``` +npm link +``` + +__Note for Windows users:__ The Angular CLI has troubles to use linked npm packages. +Please refer to this issue https://github.com/angular/angular-cli/issues/8284 for a solution / workaround. +Published packages are not effected by this issue. + + +#### General usage + +In your Angular project: + + +``` +// without configuring providers +import { ApiModule } from ''; +import { HttpClientModule } from '@angular/common/http'; + +@NgModule({ + imports: [ + ApiModule, + // make sure to import the HttpClientModule in the AppModule only, + // see https://github.com/angular/angular/issues/20575 + HttpClientModule + ], + declarations: [ AppComponent ], + providers: [], + bootstrap: [ AppComponent ] +}) +export class AppModule {} +``` + +``` +// configuring providers +import { ApiModule, Configuration, ConfigurationParameters } from ''; + +export function apiConfigFactory (): Configuration { + const params: ConfigurationParameters = { + // set configuration parameters here. + } + return new Configuration(params); +} + +@NgModule({ + imports: [ ApiModule.forRoot(apiConfigFactory) ], + declarations: [ AppComponent ], + providers: [], + bootstrap: [ AppComponent ] +}) +export class AppModule {} +``` + +``` +// configuring providers with an authentication service that manages your access tokens +import { ApiModule, Configuration } from ''; + +@NgModule({ + imports: [ ApiModule ], + declarations: [ AppComponent ], + providers: [ + { + provide: Configuration, + useFactory: (authService: AuthService) => new Configuration( + { + basePath: environment.apiUrl, + accessToken: authService.getAccessToken.bind(authService) + } + ), + deps: [AuthService], + multi: false + } + ], + bootstrap: [ AppComponent ] +}) +export class AppModule {} +``` + +``` +import { DefaultApi } from ''; + +export class AppComponent { + constructor(private apiGateway: DefaultApi) { } +} +``` + +Note: The ApiModule is restricted to being instantiated once app wide. +This is to ensure that all services are treated as singletons. + +#### Using multiple OpenAPI files / APIs / ApiModules +In order to use multiple `ApiModules` generated from different OpenAPI files, +you can create an alias name when importing the modules +in order to avoid naming conflicts: +``` +import { ApiModule } from 'my-api-path'; +import { ApiModule as OtherApiModule } from 'my-other-api-path'; +import { HttpClientModule } from '@angular/common/http'; + +@NgModule({ + imports: [ + ApiModule, + OtherApiModule, + // make sure to import the HttpClientModule in the AppModule only, + // see https://github.com/angular/angular/issues/20575 + HttpClientModule + ] +}) +export class AppModule { + +} +``` + + +### Set service base path +If different than the generated base path, during app bootstrap, you can provide the base path to your service. + +``` +import { BASE_PATH } from ''; + +bootstrap(AppComponent, [ + { provide: BASE_PATH, useValue: 'https://your-web-service.com' }, +]); +``` +or + +``` +import { BASE_PATH } from ''; + +@NgModule({ + imports: [], + declarations: [ AppComponent ], + providers: [ provide: BASE_PATH, useValue: 'https://your-web-service.com' ], + bootstrap: [ AppComponent ] +}) +export class AppModule {} +``` + + +#### Using @angular/cli +First extend your `src/environments/*.ts` files by adding the corresponding base path: + +``` +export const environment = { + production: false, + API_BASE_PATH: 'http://127.0.0.1:8080' +}; +``` + +In the src/app/app.module.ts: +``` +import { BASE_PATH } from ''; +import { environment } from '../environments/environment'; + +@NgModule({ + declarations: [ + AppComponent + ], + imports: [ ], + providers: [{ provide: BASE_PATH, useValue: environment.API_BASE_PATH }], + bootstrap: [ AppComponent ] +}) +export class AppModule { } +``` + +### Customizing path parameter encoding + +Without further customization, only [path-parameters][parameter-locations-url] of [style][style-values-url] 'simple' +and Dates for format 'date-time' are encoded correctly. + +Other styles (e.g. "matrix") are not that easy to encode +and thus are best delegated to other libraries (e.g.: [@honoluluhenk/http-param-expander]). + +To implement your own parameter encoding (or call another library), +pass an arrow-function or method-reference to the `encodeParam` property of the Configuration-object +(see [General Usage](#general-usage) above). + +Example value for use in your Configuration-Provider: +```typescript +new Configuration({ + encodeParam: (param: Param) => myFancyParamEncoder(param), +}) +``` + +[parameter-locations-url]: https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#parameter-locations +[style-values-url]: https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#style-values +[@honoluluhenk/http-param-expander]: https://www.npmjs.com/package/@honoluluhenk/http-param-expander diff --git a/webapp/src/app/core/modules/openapi/api.module.ts b/webapp/src/app/core/modules/openapi/api.module.ts new file mode 100644 index 00000000..58d341fb --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api.module.ts @@ -0,0 +1,30 @@ +import { NgModule, ModuleWithProviders, SkipSelf, Optional } from '@angular/core'; +import { Configuration } from './configuration'; +import { HttpClient } from '@angular/common/http'; + + +@NgModule({ + imports: [], + declarations: [], + exports: [], + providers: [] +}) +export class ApiModule { + public static forRoot(configurationFactory: () => Configuration): ModuleWithProviders { + return { + ngModule: ApiModule, + providers: [ { provide: Configuration, useFactory: configurationFactory } ] + }; + } + + constructor( @Optional() @SkipSelf() parentModule: ApiModule, + @Optional() http: HttpClient) { + if (parentModule) { + throw new Error('ApiModule is already loaded. Import in your base AppModule only.'); + } + if (!http) { + throw new Error('You need to import the HttpClientModule in your AppModule! \n' + + 'See also https://github.com/angular/angular/issues/20575'); + } + } +} diff --git a/webapp/src/app/core/modules/openapi/api/api.ts b/webapp/src/app/core/modules/openapi/api/api.ts new file mode 100644 index 00000000..3016e88a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/api.ts @@ -0,0 +1,34 @@ +export * from './berries.service'; +import { BerriesService } from './berries.service'; +export * from './berries.serviceInterface'; +export * from './contests.service'; +import { ContestsService } from './contests.service'; +export * from './contests.serviceInterface'; +export * from './encounters.service'; +import { EncountersService } from './encounters.service'; +export * from './encounters.serviceInterface'; +export * from './evolution.service'; +import { EvolutionService } from './evolution.service'; +export * from './evolution.serviceInterface'; +export * from './games.service'; +import { GamesService } from './games.service'; +export * from './games.serviceInterface'; +export * from './items.service'; +import { ItemsService } from './items.service'; +export * from './items.serviceInterface'; +export * from './location.service'; +import { LocationService } from './location.service'; +export * from './location.serviceInterface'; +export * from './machines.service'; +import { MachinesService } from './machines.service'; +export * from './machines.serviceInterface'; +export * from './moves.service'; +import { MovesService } from './moves.service'; +export * from './moves.serviceInterface'; +export * from './pokemon.service'; +import { PokemonService } from './pokemon.service'; +export * from './pokemon.serviceInterface'; +export * from './utility.service'; +import { UtilityService } from './utility.service'; +export * from './utility.serviceInterface'; +export const APIS = [BerriesService, ContestsService, EncountersService, EvolutionService, GamesService, ItemsService, LocationService, MachinesService, MovesService, PokemonService, UtilityService]; diff --git a/webapp/src/app/core/modules/openapi/api/berries.service.ts b/webapp/src/app/core/modules/openapi/api/berries.service.ts new file mode 100644 index 00000000..d3e73abe --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/berries.service.ts @@ -0,0 +1,612 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { BerryDetail } from '../model/berry-detail'; +// @ts-ignore +import { BerryFirmnessDetail } from '../model/berry-firmness-detail'; +// @ts-ignore +import { BerryFlavorDetail } from '../model/berry-flavor-detail'; +// @ts-ignore +import { PaginatedBerryFirmnessSummaryList } from '../model/paginated-berry-firmness-summary-list'; +// @ts-ignore +import { PaginatedBerryFlavorSummaryList } from '../model/paginated-berry-flavor-summary-list'; +// @ts-ignore +import { PaginatedBerrySummaryList } from '../model/paginated-berry-summary-list'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + BerriesServiceInterface +} from './berries.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class BerriesService implements BerriesServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List berry firmness + * Berries can be soft or hard. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Category:Berries_by_firmness) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public berryFirmnessList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public berryFirmnessList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFirmnessList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFirmnessList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/berry-firmness/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get berry by firmness + * Berries can be soft or hard. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Category:Berries_by_firmness) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public berryFirmnessRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public berryFirmnessRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFirmnessRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFirmnessRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling berryFirmnessRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/berry-firmness/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List berry flavors + * Flavors determine whether a Pokémon will benefit or suffer from eating a berry based on their **nature**. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Flavor) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public berryFlavorList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public berryFlavorList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFlavorList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFlavorList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/berry-flavor/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get berries by flavor + * Flavors determine whether a Pokémon will benefit or suffer from eating a berry based on their **nature**. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Flavor) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public berryFlavorRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public berryFlavorRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFlavorRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryFlavorRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling berryFlavorRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/berry-flavor/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List berries + * Berries are small fruits that can provide HP and status condition restoration, stat enhancement, and even damage negation when eaten by Pokémon. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Berry) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public berryList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public berryList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/berry/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get a berry + * Berries are small fruits that can provide HP and status condition restoration, stat enhancement, and even damage negation when eaten by Pokémon. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Berry) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public berryRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public berryRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public berryRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling berryRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/berry/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/berries.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/berries.serviceInterface.ts new file mode 100644 index 00000000..32ac458a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/berries.serviceInterface.ts @@ -0,0 +1,80 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { BerryDetail } from '../model/models'; +import { BerryFirmnessDetail } from '../model/models'; +import { BerryFlavorDetail } from '../model/models'; +import { PaginatedBerryFirmnessSummaryList } from '../model/models'; +import { PaginatedBerryFlavorSummaryList } from '../model/models'; +import { PaginatedBerrySummaryList } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface BerriesServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List berry firmness + * Berries can be soft or hard. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Category:Berries_by_firmness) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + berryFirmnessList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get berry by firmness + * Berries can be soft or hard. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Category:Berries_by_firmness) for greater detail. + * @param id This parameter can be a string or an integer. + */ + berryFirmnessRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List berry flavors + * Flavors determine whether a Pokémon will benefit or suffer from eating a berry based on their **nature**. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Flavor) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + berryFlavorList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get berries by flavor + * Flavors determine whether a Pokémon will benefit or suffer from eating a berry based on their **nature**. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Flavor) for greater detail. + * @param id This parameter can be a string or an integer. + */ + berryFlavorRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List berries + * Berries are small fruits that can provide HP and status condition restoration, stat enhancement, and even damage negation when eaten by Pokémon. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Berry) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + berryList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get a berry + * Berries are small fruits that can provide HP and status condition restoration, stat enhancement, and even damage negation when eaten by Pokémon. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Berry) for greater detail. + * @param id This parameter can be a string or an integer. + */ + berryRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/contests.service.ts b/webapp/src/app/core/modules/openapi/api/contests.service.ts new file mode 100644 index 00000000..979be965 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/contests.service.ts @@ -0,0 +1,612 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { ContestEffectDetail } from '../model/contest-effect-detail'; +// @ts-ignore +import { ContestTypeDetail } from '../model/contest-type-detail'; +// @ts-ignore +import { PaginatedContestEffectSummaryList } from '../model/paginated-contest-effect-summary-list'; +// @ts-ignore +import { PaginatedContestTypeSummaryList } from '../model/paginated-contest-type-summary-list'; +// @ts-ignore +import { PaginatedSuperContestEffectSummaryList } from '../model/paginated-super-contest-effect-summary-list'; +// @ts-ignore +import { SuperContestEffectDetail } from '../model/super-contest-effect-detail'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + ContestsServiceInterface +} from './contests.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class ContestsService implements ContestsServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List contest effects + * Contest effects refer to the effects of moves when used in contests. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public contestEffectList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public contestEffectList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestEffectList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestEffectList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/contest-effect/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get contest effect + * Contest effects refer to the effects of moves when used in contests. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public contestEffectRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public contestEffectRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestEffectRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestEffectRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling contestEffectRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/contest-effect/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List contest types + * Contest types are categories judges used to weigh a Pokémon\'s condition in Pokémon contests. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Contest_condition) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public contestTypeList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public contestTypeList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestTypeList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestTypeList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/contest-type/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get contest type + * Contest types are categories judges used to weigh a Pokémon\'s condition in Pokémon contests. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Contest_condition) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public contestTypeRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public contestTypeRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestTypeRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public contestTypeRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling contestTypeRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/contest-type/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List super contest effects + * Super contest effects refer to the effects of moves when used in super contests. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public superContestEffectList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public superContestEffectList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public superContestEffectList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public superContestEffectList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/super-contest-effect/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get super contest effect + * Super contest effects refer to the effects of moves when used in super contests. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public superContestEffectRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public superContestEffectRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public superContestEffectRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public superContestEffectRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling superContestEffectRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/super-contest-effect/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/contests.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/contests.serviceInterface.ts new file mode 100644 index 00000000..0fd8f61d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/contests.serviceInterface.ts @@ -0,0 +1,80 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { ContestEffectDetail } from '../model/models'; +import { ContestTypeDetail } from '../model/models'; +import { PaginatedContestEffectSummaryList } from '../model/models'; +import { PaginatedContestTypeSummaryList } from '../model/models'; +import { PaginatedSuperContestEffectSummaryList } from '../model/models'; +import { SuperContestEffectDetail } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface ContestsServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List contest effects + * Contest effects refer to the effects of moves when used in contests. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + contestEffectList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get contest effect + * Contest effects refer to the effects of moves when used in contests. + * @param id This parameter can be a string or an integer. + */ + contestEffectRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List contest types + * Contest types are categories judges used to weigh a Pokémon\'s condition in Pokémon contests. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Contest_condition) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + contestTypeList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get contest type + * Contest types are categories judges used to weigh a Pokémon\'s condition in Pokémon contests. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Contest_condition) for greater detail. + * @param id This parameter can be a string or an integer. + */ + contestTypeRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List super contest effects + * Super contest effects refer to the effects of moves when used in super contests. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + superContestEffectList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get super contest effect + * Super contest effects refer to the effects of moves when used in super contests. + * @param id This parameter can be a string or an integer. + */ + superContestEffectRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/encounters.service.ts b/webapp/src/app/core/modules/openapi/api/encounters.service.ts new file mode 100644 index 00000000..0fd3e846 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/encounters.service.ts @@ -0,0 +1,691 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { EncounterConditionDetail } from '../model/encounter-condition-detail'; +// @ts-ignore +import { EncounterConditionValueDetail } from '../model/encounter-condition-value-detail'; +// @ts-ignore +import { EncounterMethodDetail } from '../model/encounter-method-detail'; +// @ts-ignore +import { PaginatedEncounterConditionSummaryList } from '../model/paginated-encounter-condition-summary-list'; +// @ts-ignore +import { PaginatedEncounterConditionValueSummaryList } from '../model/paginated-encounter-condition-value-summary-list'; +// @ts-ignore +import { PaginatedEncounterMethodSummaryList } from '../model/paginated-encounter-method-summary-list'; +// @ts-ignore +import { PokemonEncountersRetrieve200ResponseInner } from '../model/pokemon-encounters-retrieve200-response-inner'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + EncountersServiceInterface +} from './encounters.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class EncountersService implements EncountersServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List encounter conditions + * Conditions which affect what pokemon might appear in the wild, e.g., day or night. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public encounterConditionList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public encounterConditionList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/encounter-condition/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get encounter condition + * Conditions which affect what pokemon might appear in the wild, e.g., day or night. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public encounterConditionRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public encounterConditionRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling encounterConditionRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/encounter-condition/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List encounter condition values + * Encounter condition values are the various states that an encounter condition can have, i.e., time of day can be either day or night. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public encounterConditionValueList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public encounterConditionValueList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionValueList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionValueList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/encounter-condition-value/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get encounter condition value + * Encounter condition values are the various states that an encounter condition can have, i.e., time of day can be either day or night. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public encounterConditionValueRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public encounterConditionValueRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionValueRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterConditionValueRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling encounterConditionValueRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/encounter-condition-value/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List encounter methods + * Methods by which the player might can encounter Pokémon in the wild, e.g., walking in tall grass. Check out Bulbapedia for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public encounterMethodList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public encounterMethodList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterMethodList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterMethodList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/encounter-method/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get encounter method + * Methods by which the player might can encounter Pokémon in the wild, e.g., walking in tall grass. Check out Bulbapedia for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public encounterMethodRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public encounterMethodRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterMethodRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public encounterMethodRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling encounterMethodRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/encounter-method/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokemon encounter + * Handles Pokemon Encounters as a sub-resource. + * @param pokemonId + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonEncountersRetrieve(pokemonId: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonEncountersRetrieve(pokemonId: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>>; + public pokemonEncountersRetrieve(pokemonId: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>>; + public pokemonEncountersRetrieve(pokemonId: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (pokemonId === null || pokemonId === undefined) { + throw new Error('Required parameter pokemonId was null or undefined when calling pokemonEncountersRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon/${this.configuration.encodeParam({name: "pokemonId", value: pokemonId, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/encounters`; + return this.httpClient.request>('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/encounters.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/encounters.serviceInterface.ts new file mode 100644 index 00000000..9096cae8 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/encounters.serviceInterface.ts @@ -0,0 +1,88 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { EncounterConditionDetail } from '../model/models'; +import { EncounterConditionValueDetail } from '../model/models'; +import { EncounterMethodDetail } from '../model/models'; +import { PaginatedEncounterConditionSummaryList } from '../model/models'; +import { PaginatedEncounterConditionValueSummaryList } from '../model/models'; +import { PaginatedEncounterMethodSummaryList } from '../model/models'; +import { PokemonEncountersRetrieve200ResponseInner } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface EncountersServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List encounter conditions + * Conditions which affect what pokemon might appear in the wild, e.g., day or night. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + encounterConditionList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get encounter condition + * Conditions which affect what pokemon might appear in the wild, e.g., day or night. + * @param id This parameter can be a string or an integer. + */ + encounterConditionRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List encounter condition values + * Encounter condition values are the various states that an encounter condition can have, i.e., time of day can be either day or night. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + encounterConditionValueList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get encounter condition value + * Encounter condition values are the various states that an encounter condition can have, i.e., time of day can be either day or night. + * @param id This parameter can be a string or an integer. + */ + encounterConditionValueRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List encounter methods + * Methods by which the player might can encounter Pokémon in the wild, e.g., walking in tall grass. Check out Bulbapedia for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + encounterMethodList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get encounter method + * Methods by which the player might can encounter Pokémon in the wild, e.g., walking in tall grass. Check out Bulbapedia for greater detail. + * @param id This parameter can be a string or an integer. + */ + encounterMethodRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokemon encounter + * Handles Pokemon Encounters as a sub-resource. + * @param pokemonId + */ + pokemonEncountersRetrieve(pokemonId: string, extraHttpRequestParams?: any): Observable>; + +} diff --git a/webapp/src/app/core/modules/openapi/api/evolution.service.ts b/webapp/src/app/core/modules/openapi/api/evolution.service.ts new file mode 100644 index 00000000..a3b3e4f3 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/evolution.service.ts @@ -0,0 +1,440 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { EvolutionChainDetail } from '../model/evolution-chain-detail'; +// @ts-ignore +import { EvolutionTriggerDetail } from '../model/evolution-trigger-detail'; +// @ts-ignore +import { PaginatedEvolutionChainSummaryList } from '../model/paginated-evolution-chain-summary-list'; +// @ts-ignore +import { PaginatedEvolutionTriggerSummaryList } from '../model/paginated-evolution-trigger-summary-list'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + EvolutionServiceInterface +} from './evolution.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class EvolutionService implements EvolutionServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List evolution chains + * Evolution chains are essentially family trees. They start with the lowest stage within a family and detail evolution conditions for each as well as Pokémon they can evolve into up through the hierarchy. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public evolutionChainList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public evolutionChainList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionChainList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionChainList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/evolution-chain/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get evolution chain + * Evolution chains are essentially family trees. They start with the lowest stage within a family and detail evolution conditions for each as well as Pokémon they can evolve into up through the hierarchy. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public evolutionChainRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public evolutionChainRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionChainRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionChainRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling evolutionChainRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/evolution-chain/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List evolution triggers + * Evolution triggers are the events and conditions that cause a Pokémon to evolve. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Methods_of_evolution) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public evolutionTriggerList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public evolutionTriggerList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionTriggerList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionTriggerList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/evolution-trigger/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get evolution trigger + * Evolution triggers are the events and conditions that cause a Pokémon to evolve. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Methods_of_evolution) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public evolutionTriggerRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public evolutionTriggerRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionTriggerRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public evolutionTriggerRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling evolutionTriggerRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/evolution-trigger/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/evolution.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/evolution.serviceInterface.ts new file mode 100644 index 00000000..77cad43e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/evolution.serviceInterface.ts @@ -0,0 +1,62 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { EvolutionChainDetail } from '../model/models'; +import { EvolutionTriggerDetail } from '../model/models'; +import { PaginatedEvolutionChainSummaryList } from '../model/models'; +import { PaginatedEvolutionTriggerSummaryList } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface EvolutionServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List evolution chains + * Evolution chains are essentially family trees. They start with the lowest stage within a family and detail evolution conditions for each as well as Pokémon they can evolve into up through the hierarchy. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + evolutionChainList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get evolution chain + * Evolution chains are essentially family trees. They start with the lowest stage within a family and detail evolution conditions for each as well as Pokémon they can evolve into up through the hierarchy. + * @param id This parameter can be a string or an integer. + */ + evolutionChainRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List evolution triggers + * Evolution triggers are the events and conditions that cause a Pokémon to evolve. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Methods_of_evolution) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + evolutionTriggerList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get evolution trigger + * Evolution triggers are the events and conditions that cause a Pokémon to evolve. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Methods_of_evolution) for greater detail. + * @param id This parameter can be a string or an integer. + */ + evolutionTriggerRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/games.service.ts b/webapp/src/app/core/modules/openapi/api/games.service.ts new file mode 100644 index 00000000..62d30639 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/games.service.ts @@ -0,0 +1,784 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { GenerationDetail } from '../model/generation-detail'; +// @ts-ignore +import { PaginatedGenerationSummaryList } from '../model/paginated-generation-summary-list'; +// @ts-ignore +import { PaginatedPokedexSummaryList } from '../model/paginated-pokedex-summary-list'; +// @ts-ignore +import { PaginatedVersionGroupSummaryList } from '../model/paginated-version-group-summary-list'; +// @ts-ignore +import { PaginatedVersionSummaryList } from '../model/paginated-version-summary-list'; +// @ts-ignore +import { PokedexDetail } from '../model/pokedex-detail'; +// @ts-ignore +import { VersionDetail } from '../model/version-detail'; +// @ts-ignore +import { VersionGroupDetail } from '../model/version-group-detail'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + GamesServiceInterface +} from './games.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class GamesService implements GamesServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List genrations + * A generation is a grouping of the Pokémon games that separates them based on the Pokémon they include. In each generation, a new set of Pokémon, Moves, Abilities and Types that did not exist in the previous generation are released. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public generationList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public generationList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public generationList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public generationList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/generation/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get genration + * A generation is a grouping of the Pokémon games that separates them based on the Pokémon they include. In each generation, a new set of Pokémon, Moves, Abilities and Types that did not exist in the previous generation are released. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public generationRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public generationRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public generationRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public generationRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling generationRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/generation/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokedex + * A Pokédex is a handheld electronic encyclopedia device; one which is capable of recording and retaining information of the various Pokémon in a given region with the exception of the national dex and some smaller dexes related to portions of a region. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pokedex) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokedexList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokedexList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokedexList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokedexList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokedex/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokedex + * A Pokédex is a handheld electronic encyclopedia device; one which is capable of recording and retaining information of the various Pokémon in a given region with the exception of the national dex and some smaller dexes related to portions of a region. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pokedex) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokedexRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokedexRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokedexRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokedexRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokedexRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokedex/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List version groups + * Version groups categorize highly similar versions of the games. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public versionGroupList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public versionGroupList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionGroupList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionGroupList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/version-group/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get version group + * Version groups categorize highly similar versions of the games. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public versionGroupRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public versionGroupRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionGroupRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionGroupRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling versionGroupRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/version-group/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List versions + * Versions of the games, e.g., Red, Blue or Yellow. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public versionList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public versionList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/version/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get version + * Versions of the games, e.g., Red, Blue or Yellow. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public versionRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public versionRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public versionRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling versionRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/version/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/games.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/games.serviceInterface.ts new file mode 100644 index 00000000..e0b407e4 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/games.serviceInterface.ts @@ -0,0 +1,98 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { GenerationDetail } from '../model/models'; +import { PaginatedGenerationSummaryList } from '../model/models'; +import { PaginatedPokedexSummaryList } from '../model/models'; +import { PaginatedVersionGroupSummaryList } from '../model/models'; +import { PaginatedVersionSummaryList } from '../model/models'; +import { PokedexDetail } from '../model/models'; +import { VersionDetail } from '../model/models'; +import { VersionGroupDetail } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface GamesServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List genrations + * A generation is a grouping of the Pokémon games that separates them based on the Pokémon they include. In each generation, a new set of Pokémon, Moves, Abilities and Types that did not exist in the previous generation are released. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + generationList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get genration + * A generation is a grouping of the Pokémon games that separates them based on the Pokémon they include. In each generation, a new set of Pokémon, Moves, Abilities and Types that did not exist in the previous generation are released. + * @param id This parameter can be a string or an integer. + */ + generationRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokedex + * A Pokédex is a handheld electronic encyclopedia device; one which is capable of recording and retaining information of the various Pokémon in a given region with the exception of the national dex and some smaller dexes related to portions of a region. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pokedex) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokedexList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokedex + * A Pokédex is a handheld electronic encyclopedia device; one which is capable of recording and retaining information of the various Pokémon in a given region with the exception of the national dex and some smaller dexes related to portions of a region. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pokedex) for greater detail. + * @param id This parameter can be a string or an integer. + */ + pokedexRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List version groups + * Version groups categorize highly similar versions of the games. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + versionGroupList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get version group + * Version groups categorize highly similar versions of the games. + * @param id This parameter can be a string or an integer. + */ + versionGroupRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List versions + * Versions of the games, e.g., Red, Blue or Yellow. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + versionList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get version + * Versions of the games, e.g., Red, Blue or Yellow. + * @param id This parameter can be a string or an integer. + */ + versionRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/items.service.ts b/webapp/src/app/core/modules/openapi/api/items.service.ts new file mode 100644 index 00000000..d3710a30 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/items.service.ts @@ -0,0 +1,956 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { ItemAttributeDetail } from '../model/item-attribute-detail'; +// @ts-ignore +import { ItemCategoryDetail } from '../model/item-category-detail'; +// @ts-ignore +import { ItemDetail } from '../model/item-detail'; +// @ts-ignore +import { ItemFlingEffectDetail } from '../model/item-fling-effect-detail'; +// @ts-ignore +import { ItemPocketDetail } from '../model/item-pocket-detail'; +// @ts-ignore +import { PaginatedItemAttributeSummaryList } from '../model/paginated-item-attribute-summary-list'; +// @ts-ignore +import { PaginatedItemCategorySummaryList } from '../model/paginated-item-category-summary-list'; +// @ts-ignore +import { PaginatedItemFlingEffectSummaryList } from '../model/paginated-item-fling-effect-summary-list'; +// @ts-ignore +import { PaginatedItemPocketSummaryList } from '../model/paginated-item-pocket-summary-list'; +// @ts-ignore +import { PaginatedItemSummaryList } from '../model/paginated-item-summary-list'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + ItemsServiceInterface +} from './items.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class ItemsService implements ItemsServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List item attributes + * Item attributes define particular aspects of items, e.g.\"usable in battle\" or \"consumable\". + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemAttributeList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemAttributeList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemAttributeList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemAttributeList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-attribute/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get item attribute + * Item attributes define particular aspects of items, e.g.\"usable in battle\" or \"consumable\". + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemAttributeRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemAttributeRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemAttributeRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemAttributeRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling itemAttributeRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-attribute/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List item categories + * Item categories determine where items will be placed in the players bag. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemCategoryList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemCategoryList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemCategoryList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemCategoryList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-category/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get item category + * Item categories determine where items will be placed in the players bag. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemCategoryRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemCategoryRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemCategoryRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemCategoryRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling itemCategoryRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-category/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List item fling effects + * The various effects of the move\"Fling\" when used with different items. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemFlingEffectList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemFlingEffectList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemFlingEffectList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemFlingEffectList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-fling-effect/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get item fling effect + * The various effects of the move\"Fling\" when used with different items. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemFlingEffectRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemFlingEffectRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemFlingEffectRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemFlingEffectRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling itemFlingEffectRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-fling-effect/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List items + * An item is an object in the games which the player can pick up, keep in their bag, and use in some manner. They have various uses, including healing, powering up, helping catch Pokémon, or to access a new area. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List item pockets + * Pockets within the players bag used for storing items by category. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemPocketList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemPocketList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemPocketList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemPocketList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-pocket/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get item pocket + * Pockets within the players bag used for storing items by category. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemPocketRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemPocketRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemPocketRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemPocketRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling itemPocketRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item-pocket/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get item + * An item is an object in the games which the player can pick up, keep in their bag, and use in some manner. They have various uses, including healing, powering up, helping catch Pokémon, or to access a new area. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public itemRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public itemRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public itemRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling itemRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/item/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/items.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/items.serviceInterface.ts new file mode 100644 index 00000000..195a8250 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/items.serviceInterface.ts @@ -0,0 +1,116 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { ItemAttributeDetail } from '../model/models'; +import { ItemCategoryDetail } from '../model/models'; +import { ItemDetail } from '../model/models'; +import { ItemFlingEffectDetail } from '../model/models'; +import { ItemPocketDetail } from '../model/models'; +import { PaginatedItemAttributeSummaryList } from '../model/models'; +import { PaginatedItemCategorySummaryList } from '../model/models'; +import { PaginatedItemFlingEffectSummaryList } from '../model/models'; +import { PaginatedItemPocketSummaryList } from '../model/models'; +import { PaginatedItemSummaryList } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface ItemsServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List item attributes + * Item attributes define particular aspects of items, e.g.\"usable in battle\" or \"consumable\". + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + itemAttributeList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get item attribute + * Item attributes define particular aspects of items, e.g.\"usable in battle\" or \"consumable\". + * @param id This parameter can be a string or an integer. + */ + itemAttributeRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List item categories + * Item categories determine where items will be placed in the players bag. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + itemCategoryList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get item category + * Item categories determine where items will be placed in the players bag. + * @param id This parameter can be a string or an integer. + */ + itemCategoryRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List item fling effects + * The various effects of the move\"Fling\" when used with different items. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + itemFlingEffectList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get item fling effect + * The various effects of the move\"Fling\" when used with different items. + * @param id This parameter can be a string or an integer. + */ + itemFlingEffectRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List items + * An item is an object in the games which the player can pick up, keep in their bag, and use in some manner. They have various uses, including healing, powering up, helping catch Pokémon, or to access a new area. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + itemList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * List item pockets + * Pockets within the players bag used for storing items by category. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + itemPocketList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get item pocket + * Pockets within the players bag used for storing items by category. + * @param id This parameter can be a string or an integer. + */ + itemPocketRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * Get item + * An item is an object in the games which the player can pick up, keep in their bag, and use in some manner. They have various uses, including healing, powering up, helping catch Pokémon, or to access a new area. + * @param id This parameter can be a string or an integer. + */ + itemRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/location.service.ts b/webapp/src/app/core/modules/openapi/api/location.service.ts new file mode 100644 index 00000000..c9de9196 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/location.service.ts @@ -0,0 +1,779 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { LocationAreaDetail } from '../model/location-area-detail'; +// @ts-ignore +import { LocationDetail } from '../model/location-detail'; +// @ts-ignore +import { PaginatedLocationAreaSummaryList } from '../model/paginated-location-area-summary-list'; +// @ts-ignore +import { PaginatedLocationSummaryList } from '../model/paginated-location-summary-list'; +// @ts-ignore +import { PaginatedPalParkAreaSummaryList } from '../model/paginated-pal-park-area-summary-list'; +// @ts-ignore +import { PaginatedRegionSummaryList } from '../model/paginated-region-summary-list'; +// @ts-ignore +import { PalParkAreaDetail } from '../model/pal-park-area-detail'; +// @ts-ignore +import { RegionDetail } from '../model/region-detail'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + LocationServiceInterface +} from './location.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class LocationService implements LocationServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List location areas + * Location areas are sections of areas, such as floors in a building or cave. Each area has its own set of possible Pokémon encounters. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public locationAreaList(limit?: number, offset?: number, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public locationAreaList(limit?: number, offset?: number, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationAreaList(limit?: number, offset?: number, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationAreaList(limit?: number, offset?: number, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/location-area/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get location area + * Location areas are sections of areas, such as floors in a building or cave. Each area has its own set of possible Pokémon encounters. + * @param id A unique integer value identifying this location area. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public locationAreaRetrieve(id: number, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public locationAreaRetrieve(id: number, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationAreaRetrieve(id: number, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationAreaRetrieve(id: number, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling locationAreaRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/location-area/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "number", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List locations + * Locations that can be visited within the games. Locations make up sizable portions of regions, like cities or routes. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public locationList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public locationList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/location/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get location + * Locations that can be visited within the games. Locations make up sizable portions of regions, like cities or routes. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public locationRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public locationRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public locationRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling locationRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/location/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pal park areas + * Areas used for grouping Pokémon encounters in Pal Park. They\'re like habitats that are specific to Pal Park. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public palParkAreaList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public palParkAreaList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public palParkAreaList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public palParkAreaList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pal-park-area/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pal park area + * Areas used for grouping Pokémon encounters in Pal Park. They\'re like habitats that are specific to Pal Park. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public palParkAreaRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public palParkAreaRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public palParkAreaRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public palParkAreaRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling palParkAreaRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pal-park-area/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List regions + * A region is an organized area of the Pokémon world. Most often, the main difference between regions is the species of Pokémon that can be encountered within them. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public regionList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public regionList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public regionList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public regionList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/region/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get region + * A region is an organized area of the Pokémon world. Most often, the main difference between regions is the species of Pokémon that can be encountered within them. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public regionRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public regionRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public regionRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public regionRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling regionRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/region/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/location.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/location.serviceInterface.ts new file mode 100644 index 00000000..083cd0f1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/location.serviceInterface.ts @@ -0,0 +1,97 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { LocationAreaDetail } from '../model/models'; +import { LocationDetail } from '../model/models'; +import { PaginatedLocationAreaSummaryList } from '../model/models'; +import { PaginatedLocationSummaryList } from '../model/models'; +import { PaginatedPalParkAreaSummaryList } from '../model/models'; +import { PaginatedRegionSummaryList } from '../model/models'; +import { PalParkAreaDetail } from '../model/models'; +import { RegionDetail } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface LocationServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List location areas + * Location areas are sections of areas, such as floors in a building or cave. Each area has its own set of possible Pokémon encounters. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + */ + locationAreaList(limit?: number, offset?: number, extraHttpRequestParams?: any): Observable; + + /** + * Get location area + * Location areas are sections of areas, such as floors in a building or cave. Each area has its own set of possible Pokémon encounters. + * @param id A unique integer value identifying this location area. + */ + locationAreaRetrieve(id: number, extraHttpRequestParams?: any): Observable; + + /** + * List locations + * Locations that can be visited within the games. Locations make up sizable portions of regions, like cities or routes. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + locationList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get location + * Locations that can be visited within the games. Locations make up sizable portions of regions, like cities or routes. + * @param id This parameter can be a string or an integer. + */ + locationRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pal park areas + * Areas used for grouping Pokémon encounters in Pal Park. They\'re like habitats that are specific to Pal Park. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + palParkAreaList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pal park area + * Areas used for grouping Pokémon encounters in Pal Park. They\'re like habitats that are specific to Pal Park. + * @param id This parameter can be a string or an integer. + */ + palParkAreaRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List regions + * A region is an organized area of the Pokémon world. Most often, the main difference between regions is the species of Pokémon that can be encountered within them. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + regionList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get region + * A region is an organized area of the Pokémon world. Most often, the main difference between regions is the species of Pokémon that can be encountered within them. + * @param id This parameter can be a string or an integer. + */ + regionRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/machines.service.ts b/webapp/src/app/core/modules/openapi/api/machines.service.ts new file mode 100644 index 00000000..9cbc8c37 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/machines.service.ts @@ -0,0 +1,268 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { MachineDetail } from '../model/machine-detail'; +// @ts-ignore +import { PaginatedMachineSummaryList } from '../model/paginated-machine-summary-list'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + MachinesServiceInterface +} from './machines.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class MachinesService implements MachinesServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List machines + * Machines are the representation of items that teach moves to Pokémon. They vary from version to version, so it is not certain that one specific TM or HM corresponds to a single Machine. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public machineList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public machineList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public machineList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public machineList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/machine/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get machine + * Machines are the representation of items that teach moves to Pokémon. They vary from version to version, so it is not certain that one specific TM or HM corresponds to a single Machine. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public machineRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public machineRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public machineRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public machineRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling machineRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/machine/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/machines.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/machines.serviceInterface.ts new file mode 100644 index 00000000..8aaeb883 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/machines.serviceInterface.ts @@ -0,0 +1,44 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { MachineDetail } from '../model/models'; +import { PaginatedMachineSummaryList } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface MachinesServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List machines + * Machines are the representation of items that teach moves to Pokémon. They vary from version to version, so it is not certain that one specific TM or HM corresponds to a single Machine. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + machineList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get machine + * Machines are the representation of items that teach moves to Pokémon. They vary from version to version, so it is not certain that one specific TM or HM corresponds to a single Machine. + * @param id This parameter can be a string or an integer. + */ + machineRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/moves.service.ts b/webapp/src/app/core/modules/openapi/api/moves.service.ts new file mode 100644 index 00000000..8b8a2230 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/moves.service.ts @@ -0,0 +1,1128 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { MoveBattleStyleDetail } from '../model/move-battle-style-detail'; +// @ts-ignore +import { MoveDetail } from '../model/move-detail'; +// @ts-ignore +import { MoveLearnMethodDetail } from '../model/move-learn-method-detail'; +// @ts-ignore +import { MoveMetaAilmentDetail } from '../model/move-meta-ailment-detail'; +// @ts-ignore +import { MoveMetaCategoryDetail } from '../model/move-meta-category-detail'; +// @ts-ignore +import { MoveTargetDetail } from '../model/move-target-detail'; +// @ts-ignore +import { PaginatedMoveBattleStyleSummaryList } from '../model/paginated-move-battle-style-summary-list'; +// @ts-ignore +import { PaginatedMoveLearnMethodSummaryList } from '../model/paginated-move-learn-method-summary-list'; +// @ts-ignore +import { PaginatedMoveMetaAilmentSummaryList } from '../model/paginated-move-meta-ailment-summary-list'; +// @ts-ignore +import { PaginatedMoveMetaCategorySummaryList } from '../model/paginated-move-meta-category-summary-list'; +// @ts-ignore +import { PaginatedMoveSummaryList } from '../model/paginated-move-summary-list'; +// @ts-ignore +import { PaginatedMoveTargetSummaryList } from '../model/paginated-move-target-summary-list'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + MovesServiceInterface +} from './moves.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class MovesService implements MovesServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List move meta ailments + * Move Ailments are status conditions caused by moves used during battle. See [Bulbapedia](https://bulbapedia.bulbagarden.net/wiki/Status_condition) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveAilmentList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveAilmentList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveAilmentList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveAilmentList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-ailment/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get move meta ailment + * Move Ailments are status conditions caused by moves used during battle. See [Bulbapedia](https://bulbapedia.bulbagarden.net/wiki/Status_condition) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveAilmentRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveAilmentRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveAilmentRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveAilmentRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling moveAilmentRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-ailment/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List move battle styles + * Styles of moves when used in the Battle Palace. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Battle_Frontier_(Generation_III)) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveBattleStyleList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveBattleStyleList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveBattleStyleList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveBattleStyleList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-battle-style/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get move battle style + * Styles of moves when used in the Battle Palace. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Battle_Frontier_(Generation_III)) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveBattleStyleRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveBattleStyleRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveBattleStyleRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveBattleStyleRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling moveBattleStyleRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-battle-style/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List move meta categories + * Very general categories that loosely group move effects. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveCategoryList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveCategoryList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveCategoryList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveCategoryList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-category/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get move meta category + * Very general categories that loosely group move effects. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveCategoryRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveCategoryRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveCategoryRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveCategoryRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling moveCategoryRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-category/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List move learn methods + * Methods by which Pokémon can learn moves. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveLearnMethodList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveLearnMethodList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveLearnMethodList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveLearnMethodList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-learn-method/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get move learn method + * Methods by which Pokémon can learn moves. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveLearnMethodRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveLearnMethodRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveLearnMethodRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveLearnMethodRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling moveLearnMethodRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-learn-method/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List moves + * Moves are the skills of Pokémon in battle. In battle, a Pokémon uses one move each turn. Some moves (including those learned by Hidden Machine) can be used outside of battle as well, usually for the purpose of removing obstacles or exploring new areas. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get move + * Moves are the skills of Pokémon in battle. In battle, a Pokémon uses one move each turn. Some moves (including those learned by Hidden Machine) can be used outside of battle as well, usually for the purpose of removing obstacles or exploring new areas. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling moveRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List move targets + * Targets moves can be directed at during battle. Targets can be Pokémon, environments or even other moves. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveTargetList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveTargetList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveTargetList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveTargetList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-target/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get move target + * Targets moves can be directed at during battle. Targets can be Pokémon, environments or even other moves. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveTargetRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveTargetRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveTargetRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveTargetRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling moveTargetRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-target/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/moves.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/moves.serviceInterface.ts new file mode 100644 index 00000000..62f5aeb9 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/moves.serviceInterface.ts @@ -0,0 +1,134 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { MoveBattleStyleDetail } from '../model/models'; +import { MoveDetail } from '../model/models'; +import { MoveLearnMethodDetail } from '../model/models'; +import { MoveMetaAilmentDetail } from '../model/models'; +import { MoveMetaCategoryDetail } from '../model/models'; +import { MoveTargetDetail } from '../model/models'; +import { PaginatedMoveBattleStyleSummaryList } from '../model/models'; +import { PaginatedMoveLearnMethodSummaryList } from '../model/models'; +import { PaginatedMoveMetaAilmentSummaryList } from '../model/models'; +import { PaginatedMoveMetaCategorySummaryList } from '../model/models'; +import { PaginatedMoveSummaryList } from '../model/models'; +import { PaginatedMoveTargetSummaryList } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface MovesServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List move meta ailments + * Move Ailments are status conditions caused by moves used during battle. See [Bulbapedia](https://bulbapedia.bulbagarden.net/wiki/Status_condition) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + moveAilmentList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get move meta ailment + * Move Ailments are status conditions caused by moves used during battle. See [Bulbapedia](https://bulbapedia.bulbagarden.net/wiki/Status_condition) for greater detail. + * @param id This parameter can be a string or an integer. + */ + moveAilmentRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List move battle styles + * Styles of moves when used in the Battle Palace. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Battle_Frontier_(Generation_III)) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + moveBattleStyleList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get move battle style + * Styles of moves when used in the Battle Palace. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Battle_Frontier_(Generation_III)) for greater detail. + * @param id This parameter can be a string or an integer. + */ + moveBattleStyleRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List move meta categories + * Very general categories that loosely group move effects. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + moveCategoryList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get move meta category + * Very general categories that loosely group move effects. + * @param id This parameter can be a string or an integer. + */ + moveCategoryRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List move learn methods + * Methods by which Pokémon can learn moves. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + moveLearnMethodList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get move learn method + * Methods by which Pokémon can learn moves. + * @param id This parameter can be a string or an integer. + */ + moveLearnMethodRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List moves + * Moves are the skills of Pokémon in battle. In battle, a Pokémon uses one move each turn. Some moves (including those learned by Hidden Machine) can be used outside of battle as well, usually for the purpose of removing obstacles or exploring new areas. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + moveList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get move + * Moves are the skills of Pokémon in battle. In battle, a Pokémon uses one move each turn. Some moves (including those learned by Hidden Machine) can be used outside of battle as well, usually for the purpose of removing obstacles or exploring new areas. + * @param id This parameter can be a string or an integer. + */ + moveRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List move targets + * Targets moves can be directed at during battle. Targets can be Pokémon, environments or even other moves. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + moveTargetList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get move target + * Targets moves can be directed at during battle. Targets can be Pokémon, environments or even other moves. + * @param id This parameter can be a string or an integer. + */ + moveTargetRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/pokemon.service.ts b/webapp/src/app/core/modules/openapi/api/pokemon.service.ts new file mode 100644 index 00000000..fbdf2166 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/pokemon.service.ts @@ -0,0 +1,2846 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { AbilityDetail } from '../model/ability-detail'; +// @ts-ignore +import { CharacteristicDetail } from '../model/characteristic-detail'; +// @ts-ignore +import { EggGroupDetail } from '../model/egg-group-detail'; +// @ts-ignore +import { GenderDetail } from '../model/gender-detail'; +// @ts-ignore +import { GrowthRateDetail } from '../model/growth-rate-detail'; +// @ts-ignore +import { MoveDamageClassDetail } from '../model/move-damage-class-detail'; +// @ts-ignore +import { NatureDetail } from '../model/nature-detail'; +// @ts-ignore +import { PaginatedAbilitySummaryList } from '../model/paginated-ability-summary-list'; +// @ts-ignore +import { PaginatedCharacteristicSummaryList } from '../model/paginated-characteristic-summary-list'; +// @ts-ignore +import { PaginatedEggGroupSummaryList } from '../model/paginated-egg-group-summary-list'; +// @ts-ignore +import { PaginatedGenderSummaryList } from '../model/paginated-gender-summary-list'; +// @ts-ignore +import { PaginatedGrowthRateSummaryList } from '../model/paginated-growth-rate-summary-list'; +// @ts-ignore +import { PaginatedMoveDamageClassSummaryList } from '../model/paginated-move-damage-class-summary-list'; +// @ts-ignore +import { PaginatedNatureSummaryList } from '../model/paginated-nature-summary-list'; +// @ts-ignore +import { PaginatedPokeathlonStatSummaryList } from '../model/paginated-pokeathlon-stat-summary-list'; +// @ts-ignore +import { PaginatedPokemonColorSummaryList } from '../model/paginated-pokemon-color-summary-list'; +// @ts-ignore +import { PaginatedPokemonFormSummaryList } from '../model/paginated-pokemon-form-summary-list'; +// @ts-ignore +import { PaginatedPokemonHabitatSummaryList } from '../model/paginated-pokemon-habitat-summary-list'; +// @ts-ignore +import { PaginatedPokemonShapeSummaryList } from '../model/paginated-pokemon-shape-summary-list'; +// @ts-ignore +import { PaginatedPokemonSpeciesSummaryList } from '../model/paginated-pokemon-species-summary-list'; +// @ts-ignore +import { PaginatedPokemonSummaryList } from '../model/paginated-pokemon-summary-list'; +// @ts-ignore +import { PaginatedStatSummaryList } from '../model/paginated-stat-summary-list'; +// @ts-ignore +import { PaginatedTypeSummaryList } from '../model/paginated-type-summary-list'; +// @ts-ignore +import { PokeathlonStatDetail } from '../model/pokeathlon-stat-detail'; +// @ts-ignore +import { PokemonColorDetail } from '../model/pokemon-color-detail'; +// @ts-ignore +import { PokemonDetail } from '../model/pokemon-detail'; +// @ts-ignore +import { PokemonFormDetail } from '../model/pokemon-form-detail'; +// @ts-ignore +import { PokemonHabitatDetail } from '../model/pokemon-habitat-detail'; +// @ts-ignore +import { PokemonShapeDetail } from '../model/pokemon-shape-detail'; +// @ts-ignore +import { PokemonSpeciesDetail } from '../model/pokemon-species-detail'; +// @ts-ignore +import { StatDetail } from '../model/stat-detail'; +// @ts-ignore +import { TypeDetail } from '../model/type-detail'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + PokemonServiceInterface +} from './pokemon.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class PokemonService implements PokemonServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * Abilities provide passive effects for Pokémon in battle or in the overworld. Pokémon have multiple possible abilities but can have only one ability at a time. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Ability) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public abilityList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public abilityList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public abilityList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public abilityList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/ability/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Abilities provide passive effects for Pokémon in battle or in the overworld. Pokémon have multiple possible abilities but can have only one ability at a time. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Ability) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public abilityRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public abilityRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public abilityRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public abilityRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling abilityRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/ability/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List charecterictics + * Characteristics indicate which stat contains a Pokémon\'s highest IV. A Pokémon\'s Characteristic is determined by the remainder of its highest IV divided by 5 (gene_modulo). Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Characteristic) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public characteristicList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public characteristicList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public characteristicList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public characteristicList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/characteristic/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get characteristic + * Characteristics indicate which stat contains a Pokémon\'s highest IV. A Pokémon\'s Characteristic is determined by the remainder of its highest IV divided by 5 (gene_modulo). Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Characteristic) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public characteristicRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public characteristicRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public characteristicRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public characteristicRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling characteristicRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/characteristic/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List egg groups + * Egg Groups are categories which determine which Pokémon are able to interbreed. Pokémon may belong to either one or two Egg Groups. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Egg_Group) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public eggGroupList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public eggGroupList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public eggGroupList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public eggGroupList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/egg-group/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get egg group + * Egg Groups are categories which determine which Pokémon are able to interbreed. Pokémon may belong to either one or two Egg Groups. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Egg_Group) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public eggGroupRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public eggGroupRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public eggGroupRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public eggGroupRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling eggGroupRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/egg-group/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List genders + * Genders were introduced in Generation II for the purposes of breeding Pokémon but can also result in visual differences or even different evolutionary lines. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Gender) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public genderList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public genderList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public genderList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public genderList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/gender/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get gender + * Genders were introduced in Generation II for the purposes of breeding Pokémon but can also result in visual differences or even different evolutionary lines. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Gender) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public genderRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public genderRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public genderRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public genderRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling genderRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/gender/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List growth rates + * Growth rates are the speed with which Pokémon gain levels through experience. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Experience) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public growthRateList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public growthRateList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public growthRateList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public growthRateList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/growth-rate/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get growth rate + * Growth rates are the speed with which Pokémon gain levels through experience. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Experience) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public growthRateRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public growthRateRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public growthRateRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public growthRateRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling growthRateRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/growth-rate/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List move damage classes + * Damage classes moves can have, e.g. physical, special, or non-damaging. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveDamageClassList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveDamageClassList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveDamageClassList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveDamageClassList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-damage-class/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get move damage class + * Damage classes moves can have, e.g. physical, special, or non-damaging. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public moveDamageClassRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public moveDamageClassRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveDamageClassRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public moveDamageClassRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling moveDamageClassRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/move-damage-class/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List natures + * Natures influence how a Pokémon\'s stats grow. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Nature) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public natureList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public natureList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public natureList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public natureList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/nature/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get nature + * Natures influence how a Pokémon\'s stats grow. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Nature) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public natureRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public natureRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public natureRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public natureRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling natureRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/nature/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokeathlon stats + * Pokeathlon Stats are different attributes of a Pokémon\'s performance in Pokéathlons. In Pokéathlons, competitions happen on different courses; one for each of the different Pokéathlon stats. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9athlon) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokeathlonStatList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokeathlonStatList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokeathlonStatList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokeathlonStatList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokeathlon-stat/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokeathlon stat + * Pokeathlon Stats are different attributes of a Pokémon\'s performance in Pokéathlons. In Pokéathlons, competitions happen on different courses; one for each of the different Pokéathlon stats. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9athlon) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokeathlonStatRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokeathlonStatRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokeathlonStatRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokeathlonStatRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokeathlonStatRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokeathlon-stat/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokemon colors + * Colors used for sorting Pokémon in a Pokédex. The color listed in the Pokédex is usually the color most apparent or covering each Pokémon\'s body. No orange category exists; Pokémon that are primarily orange are listed as red or brown. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonColorList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonColorList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonColorList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonColorList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-color/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokemon color + * Colors used for sorting Pokémon in a Pokédex. The color listed in the Pokédex is usually the color most apparent or covering each Pokémon\'s body. No orange category exists; Pokémon that are primarily orange are listed as red or brown. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonColorRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonColorRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonColorRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonColorRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokemonColorRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-color/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokemon forms + * Some Pokémon may appear in one of multiple, visually different forms. These differences are purely cosmetic. For variations within a Pokémon species, which do differ in more than just visuals, the \'Pokémon\' entity is used to represent such a variety. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonFormList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonFormList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonFormList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonFormList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-form/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokemon form + * Some Pokémon may appear in one of multiple, visually different forms. These differences are purely cosmetic. For variations within a Pokémon species, which do differ in more than just visuals, the \'Pokémon\' entity is used to represent such a variety. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonFormRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonFormRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonFormRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonFormRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokemonFormRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-form/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokemom habitas + * Habitats are generally different terrain Pokémon can be found in but can also be areas designated for rare or legendary Pokémon. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonHabitatList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonHabitatList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonHabitatList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonHabitatList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-habitat/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokemom habita + * Habitats are generally different terrain Pokémon can be found in but can also be areas designated for rare or legendary Pokémon. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonHabitatRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonHabitatRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonHabitatRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonHabitatRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokemonHabitatRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-habitat/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokemon + * Pokémon are the creatures that inhabit the world of the Pokémon games. They can be caught using Pokéballs and trained by battling with other Pokémon. Each Pokémon belongs to a specific species but may take on a variant which makes it differ from other Pokémon of the same species, such as base stats, available abilities and typings. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_(species)) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokemon + * Pokémon are the creatures that inhabit the world of the Pokémon games. They can be caught using Pokéballs and trained by battling with other Pokémon. Each Pokémon belongs to a specific species but may take on a variant which makes it differ from other Pokémon of the same species, such as base stats, available abilities and typings. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_(species)) for greater detail. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokemonRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokemon shapes + * Shapes used for sorting Pokémon in a Pokédex. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonShapeList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonShapeList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonShapeList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonShapeList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-shape/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokemon shape + * Shapes used for sorting Pokémon in a Pokédex. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonShapeRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonShapeRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonShapeRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonShapeRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokemonShapeRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-shape/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List pokemon species + * A Pokémon Species forms the basis for at least one Pokémon. Attributes of a Pokémon species are shared across all varieties of Pokémon within the species. A good example is Wormadam; Wormadam is the species which can be found in three different varieties, Wormadam-Trash, Wormadam-Sandy and Wormadam-Plant. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonSpeciesList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonSpeciesList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonSpeciesList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonSpeciesList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-species/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get pokemon species + * A Pokémon Species forms the basis for at least one Pokémon. Attributes of a Pokémon species are shared across all varieties of Pokémon within the species. A good example is Wormadam; Wormadam is the species which can be found in three different varieties, Wormadam-Trash, Wormadam-Sandy and Wormadam-Plant. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public pokemonSpeciesRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public pokemonSpeciesRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonSpeciesRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public pokemonSpeciesRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling pokemonSpeciesRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/pokemon-species/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List stats + * Stats determine certain aspects of battles. Each Pokémon has a value for each stat which grows as they gain levels and can be altered momentarily by effects in battles. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public statList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public statList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public statList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public statList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/stat/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get stat + * Stats determine certain aspects of battles. Each Pokémon has a value for each stat which grows as they gain levels and can be altered momentarily by effects in battles. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public statRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public statRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public statRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public statRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling statRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/stat/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * List types + * Types are properties for Pokémon and their moves. Each type has three properties: which types of Pokémon it is super effective against, which types of Pokémon it is not very effective against, and which types of Pokémon it is completely ineffective against. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public typeList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public typeList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public typeList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public typeList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/type/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get types + * Types are properties for Pokémon and their moves. Each type has three properties: which types of Pokémon it is super effective against, which types of Pokémon it is not very effective against, and which types of Pokémon it is completely ineffective against. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public typeRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public typeRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public typeRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public typeRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling typeRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/type/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/pokemon.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/pokemon.serviceInterface.ts new file mode 100644 index 00000000..3cac33ff --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/pokemon.serviceInterface.ts @@ -0,0 +1,314 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { AbilityDetail } from '../model/models'; +import { CharacteristicDetail } from '../model/models'; +import { EggGroupDetail } from '../model/models'; +import { GenderDetail } from '../model/models'; +import { GrowthRateDetail } from '../model/models'; +import { MoveDamageClassDetail } from '../model/models'; +import { NatureDetail } from '../model/models'; +import { PaginatedAbilitySummaryList } from '../model/models'; +import { PaginatedCharacteristicSummaryList } from '../model/models'; +import { PaginatedEggGroupSummaryList } from '../model/models'; +import { PaginatedGenderSummaryList } from '../model/models'; +import { PaginatedGrowthRateSummaryList } from '../model/models'; +import { PaginatedMoveDamageClassSummaryList } from '../model/models'; +import { PaginatedNatureSummaryList } from '../model/models'; +import { PaginatedPokeathlonStatSummaryList } from '../model/models'; +import { PaginatedPokemonColorSummaryList } from '../model/models'; +import { PaginatedPokemonFormSummaryList } from '../model/models'; +import { PaginatedPokemonHabitatSummaryList } from '../model/models'; +import { PaginatedPokemonShapeSummaryList } from '../model/models'; +import { PaginatedPokemonSpeciesSummaryList } from '../model/models'; +import { PaginatedPokemonSummaryList } from '../model/models'; +import { PaginatedStatSummaryList } from '../model/models'; +import { PaginatedTypeSummaryList } from '../model/models'; +import { PokeathlonStatDetail } from '../model/models'; +import { PokemonColorDetail } from '../model/models'; +import { PokemonDetail } from '../model/models'; +import { PokemonFormDetail } from '../model/models'; +import { PokemonHabitatDetail } from '../model/models'; +import { PokemonShapeDetail } from '../model/models'; +import { PokemonSpeciesDetail } from '../model/models'; +import { StatDetail } from '../model/models'; +import { TypeDetail } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface PokemonServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * + * Abilities provide passive effects for Pokémon in battle or in the overworld. Pokémon have multiple possible abilities but can have only one ability at a time. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Ability) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + abilityList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * + * Abilities provide passive effects for Pokémon in battle or in the overworld. Pokémon have multiple possible abilities but can have only one ability at a time. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Ability) for greater detail. + * @param id This parameter can be a string or an integer. + */ + abilityRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List charecterictics + * Characteristics indicate which stat contains a Pokémon\'s highest IV. A Pokémon\'s Characteristic is determined by the remainder of its highest IV divided by 5 (gene_modulo). Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Characteristic) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + characteristicList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get characteristic + * Characteristics indicate which stat contains a Pokémon\'s highest IV. A Pokémon\'s Characteristic is determined by the remainder of its highest IV divided by 5 (gene_modulo). Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Characteristic) for greater detail. + * @param id This parameter can be a string or an integer. + */ + characteristicRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List egg groups + * Egg Groups are categories which determine which Pokémon are able to interbreed. Pokémon may belong to either one or two Egg Groups. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Egg_Group) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + eggGroupList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get egg group + * Egg Groups are categories which determine which Pokémon are able to interbreed. Pokémon may belong to either one or two Egg Groups. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Egg_Group) for greater detail. + * @param id This parameter can be a string or an integer. + */ + eggGroupRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List genders + * Genders were introduced in Generation II for the purposes of breeding Pokémon but can also result in visual differences or even different evolutionary lines. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Gender) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + genderList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get gender + * Genders were introduced in Generation II for the purposes of breeding Pokémon but can also result in visual differences or even different evolutionary lines. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Gender) for greater detail. + * @param id This parameter can be a string or an integer. + */ + genderRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List growth rates + * Growth rates are the speed with which Pokémon gain levels through experience. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Experience) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + growthRateList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get growth rate + * Growth rates are the speed with which Pokémon gain levels through experience. Check out [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Experience) for greater detail. + * @param id This parameter can be a string or an integer. + */ + growthRateRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List move damage classes + * Damage classes moves can have, e.g. physical, special, or non-damaging. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + moveDamageClassList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get move damage class + * Damage classes moves can have, e.g. physical, special, or non-damaging. + * @param id This parameter can be a string or an integer. + */ + moveDamageClassRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List natures + * Natures influence how a Pokémon\'s stats grow. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Nature) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + natureList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get nature + * Natures influence how a Pokémon\'s stats grow. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Nature) for greater detail. + * @param id This parameter can be a string or an integer. + */ + natureRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokeathlon stats + * Pokeathlon Stats are different attributes of a Pokémon\'s performance in Pokéathlons. In Pokéathlons, competitions happen on different courses; one for each of the different Pokéathlon stats. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9athlon) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokeathlonStatList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokeathlon stat + * Pokeathlon Stats are different attributes of a Pokémon\'s performance in Pokéathlons. In Pokéathlons, competitions happen on different courses; one for each of the different Pokéathlon stats. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9athlon) for greater detail. + * @param id This parameter can be a string or an integer. + */ + pokeathlonStatRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokemon colors + * Colors used for sorting Pokémon in a Pokédex. The color listed in the Pokédex is usually the color most apparent or covering each Pokémon\'s body. No orange category exists; Pokémon that are primarily orange are listed as red or brown. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokemonColorList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokemon color + * Colors used for sorting Pokémon in a Pokédex. The color listed in the Pokédex is usually the color most apparent or covering each Pokémon\'s body. No orange category exists; Pokémon that are primarily orange are listed as red or brown. + * @param id This parameter can be a string or an integer. + */ + pokemonColorRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokemon forms + * Some Pokémon may appear in one of multiple, visually different forms. These differences are purely cosmetic. For variations within a Pokémon species, which do differ in more than just visuals, the \'Pokémon\' entity is used to represent such a variety. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokemonFormList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokemon form + * Some Pokémon may appear in one of multiple, visually different forms. These differences are purely cosmetic. For variations within a Pokémon species, which do differ in more than just visuals, the \'Pokémon\' entity is used to represent such a variety. + * @param id This parameter can be a string or an integer. + */ + pokemonFormRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokemom habitas + * Habitats are generally different terrain Pokémon can be found in but can also be areas designated for rare or legendary Pokémon. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokemonHabitatList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokemom habita + * Habitats are generally different terrain Pokémon can be found in but can also be areas designated for rare or legendary Pokémon. + * @param id This parameter can be a string or an integer. + */ + pokemonHabitatRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokemon + * Pokémon are the creatures that inhabit the world of the Pokémon games. They can be caught using Pokéballs and trained by battling with other Pokémon. Each Pokémon belongs to a specific species but may take on a variant which makes it differ from other Pokémon of the same species, such as base stats, available abilities and typings. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_(species)) for greater detail. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokemonList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokemon + * Pokémon are the creatures that inhabit the world of the Pokémon games. They can be caught using Pokéballs and trained by battling with other Pokémon. Each Pokémon belongs to a specific species but may take on a variant which makes it differ from other Pokémon of the same species, such as base stats, available abilities and typings. See [Bulbapedia](http://bulbapedia.bulbagarden.net/wiki/Pok%C3%A9mon_(species)) for greater detail. + * @param id This parameter can be a string or an integer. + */ + pokemonRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokemon shapes + * Shapes used for sorting Pokémon in a Pokédex. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokemonShapeList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokemon shape + * Shapes used for sorting Pokémon in a Pokédex. + * @param id This parameter can be a string or an integer. + */ + pokemonShapeRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List pokemon species + * A Pokémon Species forms the basis for at least one Pokémon. Attributes of a Pokémon species are shared across all varieties of Pokémon within the species. A good example is Wormadam; Wormadam is the species which can be found in three different varieties, Wormadam-Trash, Wormadam-Sandy and Wormadam-Plant. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + pokemonSpeciesList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get pokemon species + * A Pokémon Species forms the basis for at least one Pokémon. Attributes of a Pokémon species are shared across all varieties of Pokémon within the species. A good example is Wormadam; Wormadam is the species which can be found in three different varieties, Wormadam-Trash, Wormadam-Sandy and Wormadam-Plant. + * @param id This parameter can be a string or an integer. + */ + pokemonSpeciesRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List stats + * Stats determine certain aspects of battles. Each Pokémon has a value for each stat which grows as they gain levels and can be altered momentarily by effects in battles. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + statList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get stat + * Stats determine certain aspects of battles. Each Pokémon has a value for each stat which grows as they gain levels and can be altered momentarily by effects in battles. + * @param id This parameter can be a string or an integer. + */ + statRetrieve(id: string, extraHttpRequestParams?: any): Observable; + + /** + * List types + * Types are properties for Pokémon and their moves. Each type has three properties: which types of Pokémon it is super effective against, which types of Pokémon it is not very effective against, and which types of Pokémon it is completely ineffective against. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + typeList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get types + * Types are properties for Pokémon and their moves. Each type has three properties: which types of Pokémon it is super effective against, which types of Pokémon it is not very effective against, and which types of Pokémon it is completely ineffective against. + * @param id This parameter can be a string or an integer. + */ + typeRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/api/utility.service.ts b/webapp/src/app/core/modules/openapi/api/utility.service.ts new file mode 100644 index 00000000..ed315fb2 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/utility.service.ts @@ -0,0 +1,268 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +/* tslint:disable:no-unused-variable member-ordering */ + +import { Inject, Injectable, Optional } from '@angular/core'; +import { HttpClient, HttpHeaders, HttpParams, + HttpResponse, HttpEvent, HttpParameterCodec, HttpContext + } from '@angular/common/http'; +import { CustomHttpParameterCodec } from '../encoder'; +import { Observable } from 'rxjs'; + +// @ts-ignore +import { LanguageDetail } from '../model/language-detail'; +// @ts-ignore +import { PaginatedLanguageSummaryList } from '../model/paginated-language-summary-list'; + +// @ts-ignore +import { BASE_PATH, COLLECTION_FORMATS } from '../variables'; +import { Configuration } from '../configuration'; +import { + UtilityServiceInterface +} from './utility.serviceInterface'; + + + +@Injectable({ + providedIn: 'root' +}) +export class UtilityService implements UtilityServiceInterface { + + protected basePath = 'https://pokeapi.co'; + public defaultHeaders = new HttpHeaders(); + public configuration = new Configuration(); + public encoder: HttpParameterCodec; + + constructor(protected httpClient: HttpClient, @Optional()@Inject(BASE_PATH) basePath: string|string[], @Optional() configuration: Configuration) { + if (configuration) { + this.configuration = configuration; + } + if (typeof this.configuration.basePath !== 'string') { + const firstBasePath = Array.isArray(basePath) ? basePath[0] : undefined; + if (firstBasePath != undefined) { + basePath = firstBasePath; + } + + if (typeof basePath !== 'string') { + basePath = this.basePath; + } + this.configuration.basePath = basePath; + } + this.encoder = this.configuration.encoder || new CustomHttpParameterCodec(); + } + + + // @ts-ignore + private addToHttpParams(httpParams: HttpParams, value: any, key?: string): HttpParams { + if (typeof value === "object" && value instanceof Date === false) { + httpParams = this.addToHttpParamsRecursive(httpParams, value); + } else { + httpParams = this.addToHttpParamsRecursive(httpParams, value, key); + } + return httpParams; + } + + private addToHttpParamsRecursive(httpParams: HttpParams, value?: any, key?: string): HttpParams { + if (value == null) { + return httpParams; + } + + if (typeof value === "object") { + if (Array.isArray(value)) { + (value as any[]).forEach( elem => httpParams = this.addToHttpParamsRecursive(httpParams, elem, key)); + } else if (value instanceof Date) { + if (key != null) { + httpParams = httpParams.append(key, (value as Date).toISOString().substring(0, 10)); + } else { + throw Error("key may not be null if value is Date"); + } + } else { + Object.keys(value).forEach( k => httpParams = this.addToHttpParamsRecursive( + httpParams, value[k], key != null ? `${key}.${k}` : k)); + } + } else if (key != null) { + httpParams = httpParams.append(key, value); + } else { + throw Error("key may not be null if value is not object or array"); + } + return httpParams; + } + + /** + * List languages + * Languages for translations of API resource information. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public languageList(limit?: number, offset?: number, q?: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public languageList(limit?: number, offset?: number, q?: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public languageList(limit?: number, offset?: number, q?: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public languageList(limit?: number, offset?: number, q?: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + + let localVarQueryParameters = new HttpParams({encoder: this.encoder}); + if (limit !== undefined && limit !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + limit, 'limit'); + } + if (offset !== undefined && offset !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + offset, 'offset'); + } + if (q !== undefined && q !== null) { + localVarQueryParameters = this.addToHttpParams(localVarQueryParameters, + q, 'q'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/language/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + params: localVarQueryParameters, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + + /** + * Get language + * Languages for translations of API resource information. + * @param id This parameter can be a string or an integer. + * @param observe set whether or not to return the data Observable as the body, response or events. defaults to returning the body. + * @param reportProgress flag to report request and response progress. + */ + public languageRetrieve(id: string, observe?: 'body', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable; + public languageRetrieve(id: string, observe?: 'response', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public languageRetrieve(id: string, observe?: 'events', reportProgress?: boolean, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable>; + public languageRetrieve(id: string, observe: any = 'body', reportProgress: boolean = false, options?: {httpHeaderAccept?: 'application/json', context?: HttpContext, transferCache?: boolean}): Observable { + if (id === null || id === undefined) { + throw new Error('Required parameter id was null or undefined when calling languageRetrieve.'); + } + + let localVarHeaders = this.defaultHeaders; + + let localVarCredential: string | undefined; + // authentication (basicAuth) required + localVarCredential = this.configuration.lookupCredential('basicAuth'); + if (localVarCredential) { + localVarHeaders = localVarHeaders.set('Authorization', 'Basic ' + localVarCredential); + } + + // authentication (cookieAuth) required + localVarCredential = this.configuration.lookupCredential('cookieAuth'); + if (localVarCredential) { + } + + let localVarHttpHeaderAcceptSelected: string | undefined = options && options.httpHeaderAccept; + if (localVarHttpHeaderAcceptSelected === undefined) { + // to determine the Accept header + const httpHeaderAccepts: string[] = [ + 'application/json' + ]; + localVarHttpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts); + } + if (localVarHttpHeaderAcceptSelected !== undefined) { + localVarHeaders = localVarHeaders.set('Accept', localVarHttpHeaderAcceptSelected); + } + + let localVarHttpContext: HttpContext | undefined = options && options.context; + if (localVarHttpContext === undefined) { + localVarHttpContext = new HttpContext(); + } + + let localVarTransferCache: boolean | undefined = options && options.transferCache; + if (localVarTransferCache === undefined) { + localVarTransferCache = true; + } + + + let responseType_: 'text' | 'json' | 'blob' = 'json'; + if (localVarHttpHeaderAcceptSelected) { + if (localVarHttpHeaderAcceptSelected.startsWith('text')) { + responseType_ = 'text'; + } else if (this.configuration.isJsonMime(localVarHttpHeaderAcceptSelected)) { + responseType_ = 'json'; + } else { + responseType_ = 'blob'; + } + } + + let localVarPath = `/api/v2/language/${this.configuration.encodeParam({name: "id", value: id, in: "path", style: "simple", explode: false, dataType: "string", dataFormat: undefined})}/`; + return this.httpClient.request('get', `${this.configuration.basePath}${localVarPath}`, + { + context: localVarHttpContext, + responseType: responseType_, + withCredentials: this.configuration.withCredentials, + headers: localVarHeaders, + observe: observe, + transferCache: localVarTransferCache, + reportProgress: reportProgress + } + ); + } + +} diff --git a/webapp/src/app/core/modules/openapi/api/utility.serviceInterface.ts b/webapp/src/app/core/modules/openapi/api/utility.serviceInterface.ts new file mode 100644 index 00000000..d364c168 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/api/utility.serviceInterface.ts @@ -0,0 +1,44 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { HttpHeaders } from '@angular/common/http'; + +import { Observable } from 'rxjs'; + +import { LanguageDetail } from '../model/models'; +import { PaginatedLanguageSummaryList } from '../model/models'; + + +import { Configuration } from '../configuration'; + + + +export interface UtilityServiceInterface { + defaultHeaders: HttpHeaders; + configuration: Configuration; + + /** + * List languages + * Languages for translations of API resource information. + * @param limit Number of results to return per page. + * @param offset The initial index from which to return the results. + * @param q > Only available locally and not at [pokeapi.co](https://pokeapi.co/docs/v2) Case-insensitive query applied on the `name` property. + */ + languageList(limit?: number, offset?: number, q?: string, extraHttpRequestParams?: any): Observable; + + /** + * Get language + * Languages for translations of API resource information. + * @param id This parameter can be a string or an integer. + */ + languageRetrieve(id: string, extraHttpRequestParams?: any): Observable; + +} diff --git a/webapp/src/app/core/modules/openapi/configuration.ts b/webapp/src/app/core/modules/openapi/configuration.ts new file mode 100644 index 00000000..4cbb0d0f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/configuration.ts @@ -0,0 +1,186 @@ +import { HttpParameterCodec } from '@angular/common/http'; +import { Param } from './param'; + +export interface ConfigurationParameters { + /** + * @deprecated Since 5.0. Use credentials instead + */ + apiKeys?: {[ key: string ]: string}; + username?: string; + password?: string; + /** + * @deprecated Since 5.0. Use credentials instead + */ + accessToken?: string | (() => string); + basePath?: string; + withCredentials?: boolean; + /** + * Takes care of encoding query- and form-parameters. + */ + encoder?: HttpParameterCodec; + /** + * Override the default method for encoding path parameters in various + * styles. + *

+ * See {@link README.md} for more details + *

+ */ + encodeParam?: (param: Param) => string; + /** + * The keys are the names in the securitySchemes section of the OpenAPI + * document. They should map to the value used for authentication + * minus any standard prefixes such as 'Basic' or 'Bearer'. + */ + credentials?: {[ key: string ]: string | (() => string | undefined)}; +} + +export class Configuration { + /** + * @deprecated Since 5.0. Use credentials instead + */ + apiKeys?: {[ key: string ]: string}; + username?: string; + password?: string; + /** + * @deprecated Since 5.0. Use credentials instead + */ + accessToken?: string | (() => string); + basePath?: string; + withCredentials?: boolean; + /** + * Takes care of encoding query- and form-parameters. + */ + encoder?: HttpParameterCodec; + /** + * Encoding of various path parameter + * styles. + *

+ * See {@link README.md} for more details + *

+ */ + encodeParam: (param: Param) => string; + /** + * The keys are the names in the securitySchemes section of the OpenAPI + * document. They should map to the value used for authentication + * minus any standard prefixes such as 'Basic' or 'Bearer'. + */ + credentials: {[ key: string ]: string | (() => string | undefined)}; + + constructor(configurationParameters: ConfigurationParameters = {}) { + this.apiKeys = configurationParameters.apiKeys; + this.username = configurationParameters.username; + this.password = configurationParameters.password; + this.accessToken = configurationParameters.accessToken; + this.basePath = configurationParameters.basePath; + this.withCredentials = configurationParameters.withCredentials; + this.encoder = configurationParameters.encoder; + if (configurationParameters.encodeParam) { + this.encodeParam = configurationParameters.encodeParam; + } + else { + this.encodeParam = param => this.defaultEncodeParam(param); + } + if (configurationParameters.credentials) { + this.credentials = configurationParameters.credentials; + } + else { + this.credentials = {}; + } + + // init default basicAuth credential + if (!this.credentials['basicAuth']) { + this.credentials['basicAuth'] = () => { + return (this.username || this.password) + ? btoa(this.username + ':' + this.password) + : undefined; + }; + } + + // init default cookieAuth credential + if (!this.credentials['cookieAuth']) { + this.credentials['cookieAuth'] = () => { + if (this.apiKeys === null || this.apiKeys === undefined) { + return undefined; + } else { + return this.apiKeys['cookieAuth'] || this.apiKeys['sessionid']; + } + }; + } + } + + /** + * Select the correct content-type to use for a request. + * Uses {@link Configuration#isJsonMime} to determine the correct content-type. + * If no content type is found return the first found type if the contentTypes is not empty + * @param contentTypes - the array of content types that are available for selection + * @returns the selected content-type or undefined if no selection could be made. + */ + public selectHeaderContentType (contentTypes: string[]): string | undefined { + if (contentTypes.length === 0) { + return undefined; + } + + const type = contentTypes.find((x: string) => this.isJsonMime(x)); + if (type === undefined) { + return contentTypes[0]; + } + return type; + } + + /** + * Select the correct accept content-type to use for a request. + * Uses {@link Configuration#isJsonMime} to determine the correct accept content-type. + * If no content type is found return the first found type if the contentTypes is not empty + * @param accepts - the array of content types that are available for selection. + * @returns the selected content-type or undefined if no selection could be made. + */ + public selectHeaderAccept(accepts: string[]): string | undefined { + if (accepts.length === 0) { + return undefined; + } + + const type = accepts.find((x: string) => this.isJsonMime(x)); + if (type === undefined) { + return accepts[0]; + } + return type; + } + + /** + * Check if the given MIME is a JSON MIME. + * JSON MIME examples: + * application/json + * application/json; charset=UTF8 + * APPLICATION/JSON + * application/vnd.company+json + * @param mime - MIME (Multipurpose Internet Mail Extensions) + * @return True if the given MIME is JSON, false otherwise. + */ + public isJsonMime(mime: string): boolean { + const jsonMime: RegExp = new RegExp('^(application\/json|[^;/ \t]+\/[^;/ \t]+[+]json)[ \t]*(;.*)?$', 'i'); + return mime !== null && (jsonMime.test(mime) || mime.toLowerCase() === 'application/json-patch+json'); + } + + public lookupCredential(key: string): string | undefined { + const value = this.credentials[key]; + return typeof value === 'function' + ? value() + : value; + } + + private defaultEncodeParam(param: Param): string { + // This implementation exists as fallback for missing configuration + // and for backwards compatibility to older typescript-angular generator versions. + // It only works for the 'simple' parameter style. + // Date-handling only works for the 'date-time' format. + // All other styles and Date-formats are probably handled incorrectly. + // + // But: if that's all you need (i.e.: the most common use-case): no need for customization! + + const value = param.dataFormat === 'date-time' && param.value instanceof Date + ? (param.value as Date).toISOString() + : param.value; + + return encodeURIComponent(String(value)); + } +} diff --git a/webapp/src/app/core/modules/openapi/encoder.ts b/webapp/src/app/core/modules/openapi/encoder.ts new file mode 100644 index 00000000..138c4d5c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/encoder.ts @@ -0,0 +1,20 @@ +import { HttpParameterCodec } from '@angular/common/http'; + +/** + * Custom HttpParameterCodec + * Workaround for https://github.com/angular/angular/issues/18261 + */ +export class CustomHttpParameterCodec implements HttpParameterCodec { + encodeKey(k: string): string { + return encodeURIComponent(k); + } + encodeValue(v: string): string { + return encodeURIComponent(v); + } + decodeKey(k: string): string { + return decodeURIComponent(k); + } + decodeValue(v: string): string { + return decodeURIComponent(v); + } +} diff --git a/webapp/src/app/core/modules/openapi/git_push.sh b/webapp/src/app/core/modules/openapi/git_push.sh new file mode 100644 index 00000000..f53a75d4 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/git_push.sh @@ -0,0 +1,57 @@ +#!/bin/sh +# ref: https://help.github.com/articles/adding-an-existing-project-to-github-using-the-command-line/ +# +# Usage example: /bin/sh ./git_push.sh wing328 openapi-petstore-perl "minor update" "gitlab.com" + +git_user_id=$1 +git_repo_id=$2 +release_note=$3 +git_host=$4 + +if [ "$git_host" = "" ]; then + git_host="github.com" + echo "[INFO] No command line input provided. Set \$git_host to $git_host" +fi + +if [ "$git_user_id" = "" ]; then + git_user_id="GIT_USER_ID" + echo "[INFO] No command line input provided. Set \$git_user_id to $git_user_id" +fi + +if [ "$git_repo_id" = "" ]; then + git_repo_id="GIT_REPO_ID" + echo "[INFO] No command line input provided. Set \$git_repo_id to $git_repo_id" +fi + +if [ "$release_note" = "" ]; then + release_note="Minor update" + echo "[INFO] No command line input provided. Set \$release_note to $release_note" +fi + +# Initialize the local directory as a Git repository +git init + +# Adds the files in the local repository and stages them for commit. +git add . + +# Commits the tracked changes and prepares them to be pushed to a remote repository. +git commit -m "$release_note" + +# Sets the new remote +git_remote=$(git remote) +if [ "$git_remote" = "" ]; then # git remote not defined + + if [ "$GIT_TOKEN" = "" ]; then + echo "[INFO] \$GIT_TOKEN (environment variable) is not set. Using the git credential in your environment." + git remote add origin https://${git_host}/${git_user_id}/${git_repo_id}.git + else + git remote add origin https://${git_user_id}:"${GIT_TOKEN}"@${git_host}/${git_user_id}/${git_repo_id}.git + fi + +fi + +git pull origin master + +# Pushes (Forces) the changes in the local repository up to the remote repository +echo "Git pushing to https://${git_host}/${git_user_id}/${git_repo_id}.git" +git push origin master 2>&1 | grep -v 'To https' diff --git a/webapp/src/app/core/modules/openapi/index.ts b/webapp/src/app/core/modules/openapi/index.ts new file mode 100644 index 00000000..104dd3d2 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/index.ts @@ -0,0 +1,6 @@ +export * from './api/api'; +export * from './model/models'; +export * from './variables'; +export * from './configuration'; +export * from './api.module'; +export * from './param'; diff --git a/webapp/src/app/core/modules/openapi/model/ability-change-effect-text.ts b/webapp/src/app/core/modules/openapi/model/ability-change-effect-text.ts new file mode 100644 index 00000000..a920f1a7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-change-effect-text.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface AbilityChangeEffectText { + effect: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-change.ts b/webapp/src/app/core/modules/openapi/model/ability-change.ts new file mode 100644 index 00000000..5702008a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-change.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionGroupSummary } from './version-group-summary'; +import { AbilityChangeEffectText } from './ability-change-effect-text'; + + +export interface AbilityChange { + version_group: VersionGroupSummary; + effect_entries: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner-pokemon.ts b/webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner-pokemon.ts new file mode 100644 index 00000000..3b3de46d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner-pokemon.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface AbilityDetailPokemonInnerPokemon { + name: string; + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner.ts b/webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner.ts new file mode 100644 index 00000000..242af7ea --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-detail-pokemon-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface AbilityDetailPokemonInner { + is_hidden: boolean; + slot: number; + pokemon: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-detail.ts b/webapp/src/app/core/modules/openapi/model/ability-detail.ts new file mode 100644 index 00000000..936d5b61 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-detail.ts @@ -0,0 +1,31 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInner } from './ability-detail-pokemon-inner'; +import { AbilityName } from './ability-name'; +import { GenerationSummary } from './generation-summary'; +import { AbilityChange } from './ability-change'; +import { AbilityEffectText } from './ability-effect-text'; +import { AbilityFlavorText } from './ability-flavor-text'; + + +export interface AbilityDetail { + readonly id: number; + name: string; + is_main_series?: boolean; + generation: GenerationSummary; + names: Array; + effect_entries: Array; + effect_changes: Array; + flavor_text_entries: Array; + pokemon: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-effect-text.ts b/webapp/src/app/core/modules/openapi/model/ability-effect-text.ts new file mode 100644 index 00000000..8af57b45 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-effect-text.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface AbilityEffectText { + effect: string; + short_effect: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-flavor-text.ts b/webapp/src/app/core/modules/openapi/model/ability-flavor-text.ts new file mode 100644 index 00000000..d65db9f9 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-flavor-text.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; +import { VersionGroupSummary } from './version-group-summary'; + + +export interface AbilityFlavorText { + flavor_text: string; + language: LanguageSummary; + version_group: VersionGroupSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-name.ts b/webapp/src/app/core/modules/openapi/model/ability-name.ts new file mode 100644 index 00000000..c6f2d942 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface AbilityName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/ability-summary.ts b/webapp/src/app/core/modules/openapi/model/ability-summary.ts new file mode 100644 index 00000000..8c7233c5 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/ability-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface AbilitySummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner-flavor.ts b/webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner-flavor.ts new file mode 100644 index 00000000..60b5ef62 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner-flavor.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface BerryDetailFlavorsInnerFlavor { + /** + * The name of the flavor + */ + name?: string; + /** + * The URL to get more information about the flavor + */ + url?: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner.ts b/webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner.ts new file mode 100644 index 00000000..341e0179 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-detail-flavors-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryDetailFlavorsInnerFlavor } from './berry-detail-flavors-inner-flavor'; + + +export interface BerryDetailFlavorsInner { + potency: number; + flavor: BerryDetailFlavorsInnerFlavor; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-detail.ts b/webapp/src/app/core/modules/openapi/model/berry-detail.ts new file mode 100644 index 00000000..b69c7c8b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-detail.ts @@ -0,0 +1,32 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryDetailFlavorsInner } from './berry-detail-flavors-inner'; +import { TypeSummary } from './type-summary'; +import { BerryFirmnessSummary } from './berry-firmness-summary'; +import { ItemSummary } from './item-summary'; + + +export interface BerryDetail { + readonly id: number; + name: string; + growth_time: number; + max_harvest: number; + natural_gift_power: number; + size: number; + smoothness: number; + soil_dryness: number; + firmness: BerryFirmnessSummary; + flavors: Array; + item: ItemSummary; + natural_gift_type: TypeSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-firmness-detail.ts b/webapp/src/app/core/modules/openapi/model/berry-firmness-detail.ts new file mode 100644 index 00000000..da538703 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-firmness-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryFirmnessName } from './berry-firmness-name'; +import { BerrySummary } from './berry-summary'; + + +export interface BerryFirmnessDetail { + readonly id: number; + name: string; + berries: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-firmness-name.ts b/webapp/src/app/core/modules/openapi/model/berry-firmness-name.ts new file mode 100644 index 00000000..fb418474 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-firmness-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface BerryFirmnessName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-firmness-summary.ts b/webapp/src/app/core/modules/openapi/model/berry-firmness-summary.ts new file mode 100644 index 00000000..5c666a2f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-firmness-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface BerryFirmnessSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner-berry.ts b/webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner-berry.ts new file mode 100644 index 00000000..f7ff1956 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner-berry.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface BerryFlavorDetailBerriesInnerBerry { + /** + * The name of the berry + */ + name?: string; + /** + * The URL to get more information about the berry + */ + url?: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner.ts b/webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner.ts new file mode 100644 index 00000000..1582a4b1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-flavor-detail-berries-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryFlavorDetailBerriesInnerBerry } from './berry-flavor-detail-berries-inner-berry'; + + +export interface BerryFlavorDetailBerriesInner { + potency: number; + berry: BerryFlavorDetailBerriesInnerBerry; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-flavor-detail.ts b/webapp/src/app/core/modules/openapi/model/berry-flavor-detail.ts new file mode 100644 index 00000000..d6285cf8 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-flavor-detail.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryFlavorDetailBerriesInner } from './berry-flavor-detail-berries-inner'; +import { BerryFlavorName } from './berry-flavor-name'; +import { ContestTypeSummary } from './contest-type-summary'; + + +export interface BerryFlavorDetail { + readonly id: number; + name: string; + berries: Array; + contest_type: ContestTypeSummary; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-flavor-name.ts b/webapp/src/app/core/modules/openapi/model/berry-flavor-name.ts new file mode 100644 index 00000000..e113f1d6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-flavor-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface BerryFlavorName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-flavor-summary.ts b/webapp/src/app/core/modules/openapi/model/berry-flavor-summary.ts new file mode 100644 index 00000000..5ef0891e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-flavor-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface BerryFlavorSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/berry-summary.ts b/webapp/src/app/core/modules/openapi/model/berry-summary.ts new file mode 100644 index 00000000..443d1c50 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/berry-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface BerrySummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/characteristic-description.ts b/webapp/src/app/core/modules/openapi/model/characteristic-description.ts new file mode 100644 index 00000000..5a1e29d1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/characteristic-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface CharacteristicDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/characteristic-detail.ts b/webapp/src/app/core/modules/openapi/model/characteristic-detail.ts new file mode 100644 index 00000000..efc1e9e4 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/characteristic-detail.ts @@ -0,0 +1,23 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { StatSummary } from './stat-summary'; +import { CharacteristicDescription } from './characteristic-description'; + + +export interface CharacteristicDetail { + readonly id: number; + gene_modulo: number; + possible_values: Array; + highest_stat: StatSummary; + descriptions: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/characteristic-summary.ts b/webapp/src/app/core/modules/openapi/model/characteristic-summary.ts new file mode 100644 index 00000000..d2c269b5 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/characteristic-summary.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface CharacteristicSummary { + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/contest-effect-detail.ts b/webapp/src/app/core/modules/openapi/model/contest-effect-detail.ts new file mode 100644 index 00000000..4da92674 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/contest-effect-detail.ts @@ -0,0 +1,23 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ContestEffectEffectText } from './contest-effect-effect-text'; +import { ContestEffectFlavorText } from './contest-effect-flavor-text'; + + +export interface ContestEffectDetail { + readonly id: number; + appeal: number; + jam: number; + effect_entries: Array; + flavor_text_entries: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/contest-effect-effect-text.ts b/webapp/src/app/core/modules/openapi/model/contest-effect-effect-text.ts new file mode 100644 index 00000000..220a6a93 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/contest-effect-effect-text.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ContestEffectEffectText { + effect: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/contest-effect-flavor-text.ts b/webapp/src/app/core/modules/openapi/model/contest-effect-flavor-text.ts new file mode 100644 index 00000000..d2c05ab7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/contest-effect-flavor-text.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ContestEffectFlavorText { + flavor_text: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/contest-effect-summary.ts b/webapp/src/app/core/modules/openapi/model/contest-effect-summary.ts new file mode 100644 index 00000000..4e940497 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/contest-effect-summary.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ContestEffectSummary { + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/contest-type-detail.ts b/webapp/src/app/core/modules/openapi/model/contest-type-detail.ts new file mode 100644 index 00000000..ed3c456c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/contest-type-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryFlavorSummary } from './berry-flavor-summary'; +import { ContestTypeName } from './contest-type-name'; + + +export interface ContestTypeDetail { + readonly id: number; + name: string; + readonly berry_flavor: BerryFlavorSummary; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/contest-type-name.ts b/webapp/src/app/core/modules/openapi/model/contest-type-name.ts new file mode 100644 index 00000000..8c303c04 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/contest-type-name.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ContestTypeName { + name: string; + color: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/contest-type-summary.ts b/webapp/src/app/core/modules/openapi/model/contest-type-summary.ts new file mode 100644 index 00000000..aaebc4d0 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/contest-type-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ContestTypeSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/egg-group-detail-pokemon-species-inner.ts b/webapp/src/app/core/modules/openapi/model/egg-group-detail-pokemon-species-inner.ts new file mode 100644 index 00000000..7e41eac7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/egg-group-detail-pokemon-species-inner.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EggGroupDetailPokemonSpeciesInner { + /** + * Pokemon species name. + */ + name?: string; + /** + * The URL to get more information about the species + */ + url?: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/egg-group-detail.ts b/webapp/src/app/core/modules/openapi/model/egg-group-detail.ts new file mode 100644 index 00000000..683e8dad --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/egg-group-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EggGroupName } from './egg-group-name'; +import { EggGroupDetailPokemonSpeciesInner } from './egg-group-detail-pokemon-species-inner'; + + +export interface EggGroupDetail { + readonly id: number; + name: string; + names: Array; + pokemon_species: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/egg-group-name.ts b/webapp/src/app/core/modules/openapi/model/egg-group-name.ts new file mode 100644 index 00000000..8758c3da --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/egg-group-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface EggGroupName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/egg-group-summary.ts b/webapp/src/app/core/modules/openapi/model/egg-group-summary.ts new file mode 100644 index 00000000..2572e90c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/egg-group-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EggGroupSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-condition-detail.ts b/webapp/src/app/core/modules/openapi/model/encounter-condition-detail.ts new file mode 100644 index 00000000..b583aaa6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-condition-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EncounterConditionValueSummary } from './encounter-condition-value-summary'; +import { EncounterConditionName } from './encounter-condition-name'; + + +export interface EncounterConditionDetail { + readonly id: number; + name: string; + values: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-condition-name.ts b/webapp/src/app/core/modules/openapi/model/encounter-condition-name.ts new file mode 100644 index 00000000..f9bc88bb --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-condition-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface EncounterConditionName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-condition-summary.ts b/webapp/src/app/core/modules/openapi/model/encounter-condition-summary.ts new file mode 100644 index 00000000..6800b2d0 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-condition-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EncounterConditionSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-condition-value-detail.ts b/webapp/src/app/core/modules/openapi/model/encounter-condition-value-detail.ts new file mode 100644 index 00000000..d1d80748 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-condition-value-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EncounterConditionSummary } from './encounter-condition-summary'; +import { EncounterConditionValueName } from './encounter-condition-value-name'; + + +export interface EncounterConditionValueDetail { + readonly id: number; + name: string; + condition: EncounterConditionSummary; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-condition-value-name.ts b/webapp/src/app/core/modules/openapi/model/encounter-condition-value-name.ts new file mode 100644 index 00000000..542e47bd --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-condition-value-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface EncounterConditionValueName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-condition-value-summary.ts b/webapp/src/app/core/modules/openapi/model/encounter-condition-value-summary.ts new file mode 100644 index 00000000..af940a53 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-condition-value-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EncounterConditionValueSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-method-detail.ts b/webapp/src/app/core/modules/openapi/model/encounter-method-detail.ts new file mode 100644 index 00000000..30c0f7b7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-method-detail.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EncounterMethodName } from './encounter-method-name'; + + +export interface EncounterMethodDetail { + readonly id: number; + name: string; + order?: number | null; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-method-name.ts b/webapp/src/app/core/modules/openapi/model/encounter-method-name.ts new file mode 100644 index 00000000..9e89f642 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-method-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface EncounterMethodName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/encounter-method-summary.ts b/webapp/src/app/core/modules/openapi/model/encounter-method-summary.ts new file mode 100644 index 00000000..20eba81b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/encounter-method-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EncounterMethodSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner-gender.ts b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner-gender.ts new file mode 100644 index 00000000..58a4575f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner-gender.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInnerGender { + name: string; + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner.ts b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner.ts new file mode 100644 index 00000000..55ed896e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner.ts @@ -0,0 +1,36 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInnerGender } from './evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner-gender'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInner { + gender: EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInnerGender; + held_item: EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInnerGender; + item: EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInnerGender; + known_move: object; + known_move_type: object; + location: EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInnerGender; + min_affection: number; + min_beauty: number; + min_happiness: number; + min_level: number; + needs_overworld_rain: boolean; + party_species: string; + party_type: string; + relative_physical_stats: string; + time_of_day: string; + trade_species: string; + trigger: AbilityDetailPokemonInnerPokemon; + turn_upside_down: boolean; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner.ts b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner.ts new file mode 100644 index 00000000..bf8fefaa --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain-evolves-to-inner.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EvolutionChainDetailChainEvolvesToInnerEvolutionDetailsInner } from './evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface EvolutionChainDetailChainEvolvesToInner { + evolution_details: Array; + is_baby: boolean; + species: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain.ts b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain.ts new file mode 100644 index 00000000..5730e423 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail-chain.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { EvolutionChainDetailChainEvolvesToInner } from './evolution-chain-detail-chain-evolves-to-inner'; + + +export interface EvolutionChainDetailChain { + evolution_details: Array; + evolves_to: Array; + is_baby: boolean; + species: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-chain-detail.ts b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail.ts new file mode 100644 index 00000000..763bd906 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-chain-detail.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EvolutionChainDetailChain } from './evolution-chain-detail-chain'; +import { ItemSummary } from './item-summary'; + + +export interface EvolutionChainDetail { + readonly id: number; + baby_trigger_item: ItemSummary; + chain: EvolutionChainDetailChain; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-chain-summary.ts b/webapp/src/app/core/modules/openapi/model/evolution-chain-summary.ts new file mode 100644 index 00000000..a0c864fe --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-chain-summary.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EvolutionChainSummary { + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-trigger-detail.ts b/webapp/src/app/core/modules/openapi/model/evolution-trigger-detail.ts new file mode 100644 index 00000000..878cf550 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-trigger-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { EvolutionTriggerName } from './evolution-trigger-name'; + + +export interface EvolutionTriggerDetail { + readonly id: number; + name: string; + names: Array; + pokemon_species: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-trigger-name.ts b/webapp/src/app/core/modules/openapi/model/evolution-trigger-name.ts new file mode 100644 index 00000000..62b98806 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-trigger-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface EvolutionTriggerName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/evolution-trigger-summary.ts b/webapp/src/app/core/modules/openapi/model/evolution-trigger-summary.ts new file mode 100644 index 00000000..62c5ded6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/evolution-trigger-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface EvolutionTriggerSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/experience.ts b/webapp/src/app/core/modules/openapi/model/experience.ts new file mode 100644 index 00000000..1256338a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/experience.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface Experience { + level: number; + experience: number; +} + diff --git a/webapp/src/app/core/modules/openapi/model/gender-detail-pokemon-species-details-inner.ts b/webapp/src/app/core/modules/openapi/model/gender-detail-pokemon-species-details-inner.ts new file mode 100644 index 00000000..80ce924b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/gender-detail-pokemon-species-details-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface GenderDetailPokemonSpeciesDetailsInner { + rate: number; + pokemon_species: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/gender-detail.ts b/webapp/src/app/core/modules/openapi/model/gender-detail.ts new file mode 100644 index 00000000..857cbec1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/gender-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { GenderDetailPokemonSpeciesDetailsInner } from './gender-detail-pokemon-species-details-inner'; + + +export interface GenderDetail { + readonly id: number; + name: string; + pokemon_species_details: Array; + required_for_evolution: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/gender-summary.ts b/webapp/src/app/core/modules/openapi/model/gender-summary.ts new file mode 100644 index 00000000..d050bc30 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/gender-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface GenderSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/generation-detail.ts b/webapp/src/app/core/modules/openapi/model/generation-detail.ts new file mode 100644 index 00000000..f4fd77ac --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/generation-detail.ts @@ -0,0 +1,32 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionGroupSummary } from './version-group-summary'; +import { MoveSummary } from './move-summary'; +import { GenerationName } from './generation-name'; +import { TypeSummary } from './type-summary'; +import { AbilitySummary } from './ability-summary'; +import { RegionSummary } from './region-summary'; +import { PokemonSpeciesSummary } from './pokemon-species-summary'; + + +export interface GenerationDetail { + readonly id: number; + name: string; + abilities: Array; + main_region: RegionSummary; + moves: Array; + names: Array; + pokemon_species: Array; + types: Array; + version_groups: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/generation-name.ts b/webapp/src/app/core/modules/openapi/model/generation-name.ts new file mode 100644 index 00000000..cf700040 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/generation-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface GenerationName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/generation-summary.ts b/webapp/src/app/core/modules/openapi/model/generation-summary.ts new file mode 100644 index 00000000..1e1f9e03 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/generation-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface GenerationSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/growth-rate-description.ts b/webapp/src/app/core/modules/openapi/model/growth-rate-description.ts new file mode 100644 index 00000000..113c9633 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/growth-rate-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface GrowthRateDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/growth-rate-detail.ts b/webapp/src/app/core/modules/openapi/model/growth-rate-detail.ts new file mode 100644 index 00000000..e76a1555 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/growth-rate-detail.ts @@ -0,0 +1,25 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { Experience } from './experience'; +import { GrowthRateDescription } from './growth-rate-description'; +import { PokemonSpeciesSummary } from './pokemon-species-summary'; + + +export interface GrowthRateDetail { + readonly id: number; + name: string; + formula: string; + descriptions: Array; + levels: Array; + pokemon_species: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/growth-rate-summary.ts b/webapp/src/app/core/modules/openapi/model/growth-rate-summary.ts new file mode 100644 index 00000000..79611c58 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/growth-rate-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface GrowthRateSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-attribute-description.ts b/webapp/src/app/core/modules/openapi/model/item-attribute-description.ts new file mode 100644 index 00000000..8cf1769e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-attribute-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ItemAttributeDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-attribute-detail.ts b/webapp/src/app/core/modules/openapi/model/item-attribute-detail.ts new file mode 100644 index 00000000..69e5d50e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-attribute-detail.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemAttributeName } from './item-attribute-name'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { ItemAttributeDescription } from './item-attribute-description'; + + +export interface ItemAttributeDetail { + readonly id: number; + name: string; + descriptions: Array; + items: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-attribute-name.ts b/webapp/src/app/core/modules/openapi/model/item-attribute-name.ts new file mode 100644 index 00000000..1d7dcb1f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-attribute-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ItemAttributeName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-attribute-summary.ts b/webapp/src/app/core/modules/openapi/model/item-attribute-summary.ts new file mode 100644 index 00000000..4af5df2d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-attribute-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ItemAttributeSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-category-detail.ts b/webapp/src/app/core/modules/openapi/model/item-category-detail.ts new file mode 100644 index 00000000..a4aa662a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-category-detail.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemPocketSummary } from './item-pocket-summary'; +import { ItemCategoryName } from './item-category-name'; +import { ItemSummary } from './item-summary'; + + +export interface ItemCategoryDetail { + readonly id: number; + name: string; + items: Array; + names: Array; + pocket: ItemPocketSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-category-name.ts b/webapp/src/app/core/modules/openapi/model/item-category-name.ts new file mode 100644 index 00000000..09d19ed1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-category-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ItemCategoryName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-category-summary.ts b/webapp/src/app/core/modules/openapi/model/item-category-summary.ts new file mode 100644 index 00000000..ba4db5d6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-category-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ItemCategorySummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-detail-baby-trigger-for.ts b/webapp/src/app/core/modules/openapi/model/item-detail-baby-trigger-for.ts new file mode 100644 index 00000000..a7e1af41 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-detail-baby-trigger-for.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ItemDetailBabyTriggerFor { + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner-version-details-inner.ts b/webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner-version-details-inner.ts new file mode 100644 index 00000000..91465279 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner-version-details-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface ItemDetailHeldByPokemonInnerVersionDetailsInner { + rarity: number; + version: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner.ts b/webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner.ts new file mode 100644 index 00000000..d5cbb3ac --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-detail-held-by-pokemon-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { ItemDetailHeldByPokemonInnerVersionDetailsInner } from './item-detail-held-by-pokemon-inner-version-details-inner'; + + +export interface ItemDetailHeldByPokemonInner { + pokemon: AbilityDetailPokemonInnerPokemon; + version_details: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-detail-machines-inner.ts b/webapp/src/app/core/modules/openapi/model/item-detail-machines-inner.ts new file mode 100644 index 00000000..87110075 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-detail-machines-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface ItemDetailMachinesInner { + machine: string; + version_group: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-detail-sprites.ts b/webapp/src/app/core/modules/openapi/model/item-detail-sprites.ts new file mode 100644 index 00000000..a50093e9 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-detail-sprites.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ItemDetailSprites { + _default: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-detail.ts b/webapp/src/app/core/modules/openapi/model/item-detail.ts new file mode 100644 index 00000000..4fb0f21f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-detail.ts @@ -0,0 +1,42 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemDetailSprites } from './item-detail-sprites'; +import { ItemFlingEffectSummary } from './item-fling-effect-summary'; +import { ItemName } from './item-name'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { ItemCategorySummary } from './item-category-summary'; +import { ItemDetailHeldByPokemonInner } from './item-detail-held-by-pokemon-inner'; +import { ItemEffectText } from './item-effect-text'; +import { ItemGameIndex } from './item-game-index'; +import { ItemFlavorText } from './item-flavor-text'; +import { ItemDetailBabyTriggerFor } from './item-detail-baby-trigger-for'; +import { ItemDetailMachinesInner } from './item-detail-machines-inner'; + + +export interface ItemDetail { + readonly id: number; + name: string; + cost?: number | null; + fling_power?: number | null; + fling_effect: ItemFlingEffectSummary; + attributes: Array; + category: ItemCategorySummary; + effect_entries: Array; + flavor_text_entries: Array; + game_indices: Array; + names: Array; + held_by_pokemon: Array; + sprites: ItemDetailSprites; + baby_trigger_for: ItemDetailBabyTriggerFor; + machines: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-effect-text.ts b/webapp/src/app/core/modules/openapi/model/item-effect-text.ts new file mode 100644 index 00000000..deaba1a6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-effect-text.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ItemEffectText { + effect: string; + short_effect: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-flavor-text.ts b/webapp/src/app/core/modules/openapi/model/item-flavor-text.ts new file mode 100644 index 00000000..6ea98a17 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-flavor-text.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; +import { VersionGroupSummary } from './version-group-summary'; + + +export interface ItemFlavorText { + text: string; + version_group: VersionGroupSummary; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-fling-effect-detail.ts b/webapp/src/app/core/modules/openapi/model/item-fling-effect-detail.ts new file mode 100644 index 00000000..e499fc87 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-fling-effect-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemSummary } from './item-summary'; +import { ItemFlingEffectEffectText } from './item-fling-effect-effect-text'; + + +export interface ItemFlingEffectDetail { + readonly id: number; + name: string; + effect_entries: Array; + items: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-fling-effect-effect-text.ts b/webapp/src/app/core/modules/openapi/model/item-fling-effect-effect-text.ts new file mode 100644 index 00000000..9edc3023 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-fling-effect-effect-text.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ItemFlingEffectEffectText { + effect: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-fling-effect-summary.ts b/webapp/src/app/core/modules/openapi/model/item-fling-effect-summary.ts new file mode 100644 index 00000000..08d1021d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-fling-effect-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ItemFlingEffectSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-game-index.ts b/webapp/src/app/core/modules/openapi/model/item-game-index.ts new file mode 100644 index 00000000..cc7ea1ce --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-game-index.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { GenerationSummary } from './generation-summary'; + + +export interface ItemGameIndex { + game_index: number; + generation: GenerationSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-name.ts b/webapp/src/app/core/modules/openapi/model/item-name.ts new file mode 100644 index 00000000..85c9a534 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ItemName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-pocket-detail.ts b/webapp/src/app/core/modules/openapi/model/item-pocket-detail.ts new file mode 100644 index 00000000..6f6dae12 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-pocket-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemPocketName } from './item-pocket-name'; +import { ItemCategorySummary } from './item-category-summary'; + + +export interface ItemPocketDetail { + readonly id: number; + name: string; + categories: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-pocket-name.ts b/webapp/src/app/core/modules/openapi/model/item-pocket-name.ts new file mode 100644 index 00000000..d14ccf3a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-pocket-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface ItemPocketName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-pocket-summary.ts b/webapp/src/app/core/modules/openapi/model/item-pocket-summary.ts new file mode 100644 index 00000000..a8614c54 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-pocket-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ItemPocketSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/item-summary.ts b/webapp/src/app/core/modules/openapi/model/item-summary.ts new file mode 100644 index 00000000..a381e1c7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/item-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface ItemSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/language-detail.ts b/webapp/src/app/core/modules/openapi/model/language-detail.ts new file mode 100644 index 00000000..321f418c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/language-detail.ts @@ -0,0 +1,23 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageName } from './language-name'; + + +export interface LanguageDetail { + readonly id: number; + name: string; + official?: boolean; + iso639: string; + iso3166: string; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/language-name.ts b/webapp/src/app/core/modules/openapi/model/language-name.ts new file mode 100644 index 00000000..04d3285d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/language-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface LanguageName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/language-summary.ts b/webapp/src/app/core/modules/openapi/model/language-summary.ts new file mode 100644 index 00000000..bd6ed645 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/language-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface LanguageSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner-version-details-inner.ts b/webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner-version-details-inner.ts new file mode 100644 index 00000000..6556fcbd --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner-version-details-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface LocationAreaDetailEncounterMethodRatesInnerVersionDetailsInner { + rate: number; + version: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner.ts b/webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner.ts new file mode 100644 index 00000000..68f8926b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-detail-encounter-method-rates-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LocationAreaDetailEncounterMethodRatesInnerVersionDetailsInner } from './location-area-detail-encounter-method-rates-inner-version-details-inner'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface LocationAreaDetailEncounterMethodRatesInner { + encounter_method: AbilityDetailPokemonInnerPokemon; + version_details: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner-encounter-details.ts b/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner-encounter-details.ts new file mode 100644 index 00000000..dca616c1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner-encounter-details.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface LocationAreaDetailPokemonEncountersInnerVersionDetailsInnerEncounterDetails { + min_level: number; + max_level: number; + condition_values?: AbilityDetailPokemonInnerPokemon; + chance: number; + method: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner.ts b/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner.ts new file mode 100644 index 00000000..ffe60ac2 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner-version-details-inner.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LocationAreaDetailPokemonEncountersInnerVersionDetailsInnerEncounterDetails } from './location-area-detail-pokemon-encounters-inner-version-details-inner-encounter-details'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface LocationAreaDetailPokemonEncountersInnerVersionDetailsInner { + version: AbilityDetailPokemonInnerPokemon; + max_chance: number; + encounter_details: LocationAreaDetailPokemonEncountersInnerVersionDetailsInnerEncounterDetails; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner.ts b/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner.ts new file mode 100644 index 00000000..358c0375 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-detail-pokemon-encounters-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { LocationAreaDetailPokemonEncountersInnerVersionDetailsInner } from './location-area-detail-pokemon-encounters-inner-version-details-inner'; + + +export interface LocationAreaDetailPokemonEncountersInner { + pokemon: AbilityDetailPokemonInnerPokemon; + version_details: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-detail.ts b/webapp/src/app/core/modules/openapi/model/location-area-detail.ts new file mode 100644 index 00000000..1407c972 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-detail.ts @@ -0,0 +1,27 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LocationAreaName } from './location-area-name'; +import { LocationSummary } from './location-summary'; +import { LocationAreaDetailPokemonEncountersInner } from './location-area-detail-pokemon-encounters-inner'; +import { LocationAreaDetailEncounterMethodRatesInner } from './location-area-detail-encounter-method-rates-inner'; + + +export interface LocationAreaDetail { + readonly id: number; + name: string; + game_index: number; + encounter_method_rates: Array; + location: LocationSummary; + names: Array; + pokemon_encounters: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-name.ts b/webapp/src/app/core/modules/openapi/model/location-area-name.ts new file mode 100644 index 00000000..580b934a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface LocationAreaName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-area-summary.ts b/webapp/src/app/core/modules/openapi/model/location-area-summary.ts new file mode 100644 index 00000000..cdb7f3cf --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-area-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface LocationAreaSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-detail.ts b/webapp/src/app/core/modules/openapi/model/location-detail.ts new file mode 100644 index 00000000..23f53a73 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-detail.ts @@ -0,0 +1,26 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LocationGameIndex } from './location-game-index'; +import { RegionSummary } from './region-summary'; +import { LocationAreaSummary } from './location-area-summary'; +import { LocationName } from './location-name'; + + +export interface LocationDetail { + readonly id: number; + name: string; + region: RegionSummary; + names: Array; + game_indices: Array; + areas: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-game-index.ts b/webapp/src/app/core/modules/openapi/model/location-game-index.ts new file mode 100644 index 00000000..5d364858 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-game-index.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { GenerationSummary } from './generation-summary'; + + +export interface LocationGameIndex { + game_index: number; + generation: GenerationSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-name.ts b/webapp/src/app/core/modules/openapi/model/location-name.ts new file mode 100644 index 00000000..112dd243 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface LocationName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/location-summary.ts b/webapp/src/app/core/modules/openapi/model/location-summary.ts new file mode 100644 index 00000000..a687f344 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/location-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface LocationSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/machine-detail.ts b/webapp/src/app/core/modules/openapi/model/machine-detail.ts new file mode 100644 index 00000000..5329e365 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/machine-detail.ts @@ -0,0 +1,23 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionGroupSummary } from './version-group-summary'; +import { MoveSummary } from './move-summary'; +import { ItemSummary } from './item-summary'; + + +export interface MachineDetail { + readonly id: number; + item: ItemSummary; + version_group: VersionGroupSummary; + move: MoveSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/machine-summary.ts b/webapp/src/app/core/modules/openapi/model/machine-summary.ts new file mode 100644 index 00000000..d1c0b18e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/machine-summary.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MachineSummary { + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/models.ts b/webapp/src/app/core/modules/openapi/model/models.ts new file mode 100644 index 00000000..750d1878 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/models.ts @@ -0,0 +1,274 @@ +export * from './ability-change'; +export * from './ability-change-effect-text'; +export * from './ability-detail'; +export * from './ability-detail-pokemon-inner'; +export * from './ability-detail-pokemon-inner-pokemon'; +export * from './ability-effect-text'; +export * from './ability-flavor-text'; +export * from './ability-name'; +export * from './ability-summary'; +export * from './berry-detail'; +export * from './berry-detail-flavors-inner'; +export * from './berry-detail-flavors-inner-flavor'; +export * from './berry-firmness-detail'; +export * from './berry-firmness-name'; +export * from './berry-firmness-summary'; +export * from './berry-flavor-detail'; +export * from './berry-flavor-detail-berries-inner'; +export * from './berry-flavor-detail-berries-inner-berry'; +export * from './berry-flavor-name'; +export * from './berry-flavor-summary'; +export * from './berry-summary'; +export * from './characteristic-description'; +export * from './characteristic-detail'; +export * from './characteristic-summary'; +export * from './contest-effect-detail'; +export * from './contest-effect-effect-text'; +export * from './contest-effect-flavor-text'; +export * from './contest-effect-summary'; +export * from './contest-type-detail'; +export * from './contest-type-name'; +export * from './contest-type-summary'; +export * from './egg-group-detail'; +export * from './egg-group-detail-pokemon-species-inner'; +export * from './egg-group-name'; +export * from './egg-group-summary'; +export * from './encounter-condition-detail'; +export * from './encounter-condition-name'; +export * from './encounter-condition-summary'; +export * from './encounter-condition-value-detail'; +export * from './encounter-condition-value-name'; +export * from './encounter-condition-value-summary'; +export * from './encounter-method-detail'; +export * from './encounter-method-name'; +export * from './encounter-method-summary'; +export * from './evolution-chain-detail'; +export * from './evolution-chain-detail-chain'; +export * from './evolution-chain-detail-chain-evolves-to-inner'; +export * from './evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner'; +export * from './evolution-chain-detail-chain-evolves-to-inner-evolution-details-inner-gender'; +export * from './evolution-chain-summary'; +export * from './evolution-trigger-detail'; +export * from './evolution-trigger-name'; +export * from './evolution-trigger-summary'; +export * from './experience'; +export * from './gender-detail'; +export * from './gender-detail-pokemon-species-details-inner'; +export * from './gender-summary'; +export * from './generation-detail'; +export * from './generation-name'; +export * from './generation-summary'; +export * from './growth-rate-description'; +export * from './growth-rate-detail'; +export * from './growth-rate-summary'; +export * from './item-attribute-description'; +export * from './item-attribute-detail'; +export * from './item-attribute-name'; +export * from './item-attribute-summary'; +export * from './item-category-detail'; +export * from './item-category-name'; +export * from './item-category-summary'; +export * from './item-detail'; +export * from './item-detail-baby-trigger-for'; +export * from './item-detail-held-by-pokemon-inner'; +export * from './item-detail-held-by-pokemon-inner-version-details-inner'; +export * from './item-detail-machines-inner'; +export * from './item-detail-sprites'; +export * from './item-effect-text'; +export * from './item-flavor-text'; +export * from './item-fling-effect-detail'; +export * from './item-fling-effect-effect-text'; +export * from './item-fling-effect-summary'; +export * from './item-game-index'; +export * from './item-name'; +export * from './item-pocket-detail'; +export * from './item-pocket-name'; +export * from './item-pocket-summary'; +export * from './item-summary'; +export * from './language-detail'; +export * from './language-name'; +export * from './language-summary'; +export * from './location-area-detail'; +export * from './location-area-detail-encounter-method-rates-inner'; +export * from './location-area-detail-encounter-method-rates-inner-version-details-inner'; +export * from './location-area-detail-pokemon-encounters-inner'; +export * from './location-area-detail-pokemon-encounters-inner-version-details-inner'; +export * from './location-area-detail-pokemon-encounters-inner-version-details-inner-encounter-details'; +export * from './location-area-name'; +export * from './location-area-summary'; +export * from './location-detail'; +export * from './location-game-index'; +export * from './location-name'; +export * from './location-summary'; +export * from './machine-detail'; +export * from './machine-summary'; +export * from './move-battle-style-detail'; +export * from './move-battle-style-name'; +export * from './move-battle-style-summary'; +export * from './move-change'; +export * from './move-change-effect-entries-inner'; +export * from './move-damage-class-description'; +export * from './move-damage-class-detail'; +export * from './move-damage-class-name'; +export * from './move-damage-class-summary'; +export * from './move-detail'; +export * from './move-detail-contest-combos'; +export * from './move-detail-contest-combos-normal'; +export * from './move-detail-effect-changes-inner'; +export * from './move-detail-effect-changes-inner-effect-entries-inner'; +export * from './move-detail-machines-inner'; +export * from './move-detail-machines-inner-machine'; +export * from './move-detail-stat-changes-inner'; +export * from './move-flavor-text'; +export * from './move-learn-method-description'; +export * from './move-learn-method-detail'; +export * from './move-learn-method-name'; +export * from './move-learn-method-summary'; +export * from './move-meta'; +export * from './move-meta-ailment-detail'; +export * from './move-meta-ailment-name'; +export * from './move-meta-ailment-summary'; +export * from './move-meta-category-description'; +export * from './move-meta-category-detail'; +export * from './move-meta-category-summary'; +export * from './move-name'; +export * from './move-summary'; +export * from './move-target-description'; +export * from './move-target-detail'; +export * from './move-target-name'; +export * from './move-target-summary'; +export * from './nature-battle-style-preference'; +export * from './nature-detail'; +export * from './nature-detail-pokeathlon-stat-changes-inner'; +export * from './nature-name'; +export * from './nature-summary'; +export * from './paginated-ability-summary-list'; +export * from './paginated-berry-firmness-summary-list'; +export * from './paginated-berry-flavor-summary-list'; +export * from './paginated-berry-summary-list'; +export * from './paginated-characteristic-summary-list'; +export * from './paginated-contest-effect-summary-list'; +export * from './paginated-contest-type-summary-list'; +export * from './paginated-egg-group-summary-list'; +export * from './paginated-encounter-condition-summary-list'; +export * from './paginated-encounter-condition-value-summary-list'; +export * from './paginated-encounter-method-summary-list'; +export * from './paginated-evolution-chain-summary-list'; +export * from './paginated-evolution-trigger-summary-list'; +export * from './paginated-gender-summary-list'; +export * from './paginated-generation-summary-list'; +export * from './paginated-growth-rate-summary-list'; +export * from './paginated-item-attribute-summary-list'; +export * from './paginated-item-category-summary-list'; +export * from './paginated-item-fling-effect-summary-list'; +export * from './paginated-item-pocket-summary-list'; +export * from './paginated-item-summary-list'; +export * from './paginated-language-summary-list'; +export * from './paginated-location-area-summary-list'; +export * from './paginated-location-summary-list'; +export * from './paginated-machine-summary-list'; +export * from './paginated-move-battle-style-summary-list'; +export * from './paginated-move-damage-class-summary-list'; +export * from './paginated-move-learn-method-summary-list'; +export * from './paginated-move-meta-ailment-summary-list'; +export * from './paginated-move-meta-category-summary-list'; +export * from './paginated-move-summary-list'; +export * from './paginated-move-target-summary-list'; +export * from './paginated-nature-summary-list'; +export * from './paginated-pal-park-area-summary-list'; +export * from './paginated-pokeathlon-stat-summary-list'; +export * from './paginated-pokedex-summary-list'; +export * from './paginated-pokemon-color-summary-list'; +export * from './paginated-pokemon-form-summary-list'; +export * from './paginated-pokemon-habitat-summary-list'; +export * from './paginated-pokemon-shape-summary-list'; +export * from './paginated-pokemon-species-summary-list'; +export * from './paginated-pokemon-summary-list'; +export * from './paginated-region-summary-list'; +export * from './paginated-stat-summary-list'; +export * from './paginated-super-contest-effect-summary-list'; +export * from './paginated-type-summary-list'; +export * from './paginated-version-group-summary-list'; +export * from './paginated-version-summary-list'; +export * from './pal-park-area-detail'; +export * from './pal-park-area-detail-pokemon-encounters-inner'; +export * from './pal-park-area-name'; +export * from './pal-park-area-summary'; +export * from './pokeathlon-stat-detail'; +export * from './pokeathlon-stat-detail-affecting-natures'; +export * from './pokeathlon-stat-detail-affecting-natures-decrease-inner'; +export * from './pokeathlon-stat-detail-affecting-natures-increase-inner'; +export * from './pokeathlon-stat-name'; +export * from './pokeathlon-stat-summary'; +export * from './pokedex-description'; +export * from './pokedex-detail'; +export * from './pokedex-detail-pokemon-entries-inner'; +export * from './pokedex-name'; +export * from './pokedex-summary'; +export * from './pokemon-color-detail'; +export * from './pokemon-color-name'; +export * from './pokemon-color-summary'; +export * from './pokemon-detail'; +export * from './pokemon-detail-abilities-inner'; +export * from './pokemon-detail-cries'; +export * from './pokemon-detail-held-items'; +export * from './pokemon-detail-moves-inner'; +export * from './pokemon-detail-moves-inner-version-group-details-inner'; +export * from './pokemon-detail-past-abilities-inner'; +export * from './pokemon-detail-past-types-inner'; +export * from './pokemon-detail-sprites'; +export * from './pokemon-detail-types-inner'; +export * from './pokemon-dex-entry'; +export * from './pokemon-encounters-retrieve200-response-inner'; +export * from './pokemon-encounters-retrieve200-response-inner-location-area'; +export * from './pokemon-encounters-retrieve200-response-inner-version-details-inner'; +export * from './pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner'; +export * from './pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-condition-values-inner'; +export * from './pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-method'; +export * from './pokemon-encounters-retrieve200-response-inner-version-details-inner-version'; +export * from './pokemon-form-detail'; +export * from './pokemon-form-detail-form-names-inner'; +export * from './pokemon-form-detail-sprites'; +export * from './pokemon-form-summary'; +export * from './pokemon-game-index'; +export * from './pokemon-habitat-detail'; +export * from './pokemon-habitat-name'; +export * from './pokemon-habitat-summary'; +export * from './pokemon-shape-detail'; +export * from './pokemon-shape-detail-awesome-names-inner'; +export * from './pokemon-shape-detail-names-inner'; +export * from './pokemon-shape-summary'; +export * from './pokemon-species-description'; +export * from './pokemon-species-detail'; +export * from './pokemon-species-detail-genera-inner'; +export * from './pokemon-species-detail-pal-park-encounters-inner'; +export * from './pokemon-species-detail-varieties-inner'; +export * from './pokemon-species-flavor-text'; +export * from './pokemon-species-summary'; +export * from './pokemon-stat'; +export * from './pokemon-summary'; +export * from './region-detail'; +export * from './region-name'; +export * from './region-summary'; +export * from './stat-detail'; +export * from './stat-detail-affecting-moves'; +export * from './stat-detail-affecting-moves-increase-inner'; +export * from './stat-detail-affecting-natures'; +export * from './stat-name'; +export * from './stat-summary'; +export * from './super-contest-effect-detail'; +export * from './super-contest-effect-flavor-text'; +export * from './super-contest-effect-summary'; +export * from './type-detail'; +export * from './type-detail-damage-relations'; +export * from './type-detail-past-damage-relations-inner'; +export * from './type-detail-past-damage-relations-inner-damage-relations'; +export * from './type-detail-pokemon-inner'; +export * from './type-detail-pokemon-inner-pokemon'; +export * from './type-game-index'; +export * from './type-summary'; +export * from './version-detail'; +export * from './version-group-detail'; +export * from './version-group-summary'; +export * from './version-name'; +export * from './version-summary'; diff --git a/webapp/src/app/core/modules/openapi/model/move-battle-style-detail.ts b/webapp/src/app/core/modules/openapi/model/move-battle-style-detail.ts new file mode 100644 index 00000000..48df4285 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-battle-style-detail.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveBattleStyleName } from './move-battle-style-name'; + + +export interface MoveBattleStyleDetail { + readonly id: number; + name: string; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-battle-style-name.ts b/webapp/src/app/core/modules/openapi/model/move-battle-style-name.ts new file mode 100644 index 00000000..56751f58 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-battle-style-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveBattleStyleName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-battle-style-summary.ts b/webapp/src/app/core/modules/openapi/model/move-battle-style-summary.ts new file mode 100644 index 00000000..1f234fcb --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-battle-style-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveBattleStyleSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-change-effect-entries-inner.ts b/webapp/src/app/core/modules/openapi/model/move-change-effect-entries-inner.ts new file mode 100644 index 00000000..2c474a15 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-change-effect-entries-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface MoveChangeEffectEntriesInner { + effect: string; + short_effect: string; + language: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-change.ts b/webapp/src/app/core/modules/openapi/model/move-change.ts new file mode 100644 index 00000000..207b5c6d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-change.ts @@ -0,0 +1,26 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveChangeEffectEntriesInner } from './move-change-effect-entries-inner'; +import { VersionGroupSummary } from './version-group-summary'; +import { TypeSummary } from './type-summary'; + + +export interface MoveChange { + accuracy?: number | null; + power?: number | null; + pp?: number | null; + effect_chance: number; + effect_entries: Array; + type: TypeSummary; + version_group: VersionGroupSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-damage-class-description.ts b/webapp/src/app/core/modules/openapi/model/move-damage-class-description.ts new file mode 100644 index 00000000..e24a223d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-damage-class-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveDamageClassDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-damage-class-detail.ts b/webapp/src/app/core/modules/openapi/model/move-damage-class-detail.ts new file mode 100644 index 00000000..d5e6ed6c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-damage-class-detail.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveDamageClassDescription } from './move-damage-class-description'; +import { MoveSummary } from './move-summary'; +import { MoveDamageClassName } from './move-damage-class-name'; + + +export interface MoveDamageClassDetail { + readonly id: number; + name: string; + descriptions: Array; + moves: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-damage-class-name.ts b/webapp/src/app/core/modules/openapi/model/move-damage-class-name.ts new file mode 100644 index 00000000..24ccc698 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-damage-class-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveDamageClassName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-damage-class-summary.ts b/webapp/src/app/core/modules/openapi/model/move-damage-class-summary.ts new file mode 100644 index 00000000..5611dea7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-damage-class-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveDamageClassSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail-contest-combos-normal.ts b/webapp/src/app/core/modules/openapi/model/move-detail-contest-combos-normal.ts new file mode 100644 index 00000000..fef3da2f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail-contest-combos-normal.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface MoveDetailContestCombosNormal { + use_before: Array; + use_after: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail-contest-combos.ts b/webapp/src/app/core/modules/openapi/model/move-detail-contest-combos.ts new file mode 100644 index 00000000..42a2f349 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail-contest-combos.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveDetailContestCombosNormal } from './move-detail-contest-combos-normal'; + + +export interface MoveDetailContestCombos { + normal: MoveDetailContestCombosNormal; + _super: MoveDetailContestCombosNormal; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner-effect-entries-inner.ts b/webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner-effect-entries-inner.ts new file mode 100644 index 00000000..deca3406 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner-effect-entries-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface MoveDetailEffectChangesInnerEffectEntriesInner { + effect: string; + language: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner.ts b/webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner.ts new file mode 100644 index 00000000..310ea82d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail-effect-changes-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { MoveDetailEffectChangesInnerEffectEntriesInner } from './move-detail-effect-changes-inner-effect-entries-inner'; + + +export interface MoveDetailEffectChangesInner { + effect_entries: Array; + version_group: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail-machines-inner-machine.ts b/webapp/src/app/core/modules/openapi/model/move-detail-machines-inner-machine.ts new file mode 100644 index 00000000..cc7006ce --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail-machines-inner-machine.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveDetailMachinesInnerMachine { + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail-machines-inner.ts b/webapp/src/app/core/modules/openapi/model/move-detail-machines-inner.ts new file mode 100644 index 00000000..7d29b594 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail-machines-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveDetailMachinesInnerMachine } from './move-detail-machines-inner-machine'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface MoveDetailMachinesInner { + machine: MoveDetailMachinesInnerMachine; + version_group: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail-stat-changes-inner.ts b/webapp/src/app/core/modules/openapi/model/move-detail-stat-changes-inner.ts new file mode 100644 index 00000000..a71e7bd4 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail-stat-changes-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface MoveDetailStatChangesInner { + change: number; + stat: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-detail.ts b/webapp/src/app/core/modules/openapi/model/move-detail.ts new file mode 100644 index 00000000..af41fe0e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-detail.ts @@ -0,0 +1,57 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveName } from './move-name'; +import { MoveDetailEffectChangesInner } from './move-detail-effect-changes-inner'; +import { MoveFlavorText } from './move-flavor-text'; +import { GenerationSummary } from './generation-summary'; +import { ContestTypeSummary } from './contest-type-summary'; +import { MoveDetailStatChangesInner } from './move-detail-stat-changes-inner'; +import { MoveMeta } from './move-meta'; +import { TypeSummary } from './type-summary'; +import { MoveDetailContestCombos } from './move-detail-contest-combos'; +import { ContestEffectSummary } from './contest-effect-summary'; +import { MoveChangeEffectEntriesInner } from './move-change-effect-entries-inner'; +import { MoveDetailMachinesInner } from './move-detail-machines-inner'; +import { MoveDamageClassSummary } from './move-damage-class-summary'; +import { MoveTargetSummary } from './move-target-summary'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { MoveChange } from './move-change'; +import { SuperContestEffectSummary } from './super-contest-effect-summary'; + + +export interface MoveDetail { + readonly id: number; + name: string; + accuracy?: number | null; + effect_chance: number; + pp?: number | null; + priority?: number | null; + power?: number | null; + contest_combos: MoveDetailContestCombos; + contest_type: ContestTypeSummary; + contest_effect: ContestEffectSummary; + damage_class: MoveDamageClassSummary; + effect_entries: Array; + effect_changes: Array; + generation: GenerationSummary; + readonly meta: MoveMeta; + names: Array; + past_values: Array; + stat_changes: Array; + super_contest_effect: SuperContestEffectSummary; + target: MoveTargetSummary; + type: TypeSummary; + machines: Array; + flavor_text_entries: Array; + learned_by_pokemon: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-flavor-text.ts b/webapp/src/app/core/modules/openapi/model/move-flavor-text.ts new file mode 100644 index 00000000..374d5358 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-flavor-text.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; +import { VersionGroupSummary } from './version-group-summary'; + + +export interface MoveFlavorText { + flavor_text: string; + language: LanguageSummary; + version_group: VersionGroupSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-learn-method-description.ts b/webapp/src/app/core/modules/openapi/model/move-learn-method-description.ts new file mode 100644 index 00000000..f264b7d4 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-learn-method-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveLearnMethodDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-learn-method-detail.ts b/webapp/src/app/core/modules/openapi/model/move-learn-method-detail.ts new file mode 100644 index 00000000..b6b64f52 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-learn-method-detail.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveLearnMethodName } from './move-learn-method-name'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { MoveLearnMethodDescription } from './move-learn-method-description'; + + +export interface MoveLearnMethodDetail { + readonly id: number; + name: string; + names: Array; + descriptions: Array; + version_groups: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-learn-method-name.ts b/webapp/src/app/core/modules/openapi/model/move-learn-method-name.ts new file mode 100644 index 00000000..31161eef --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-learn-method-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveLearnMethodName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-learn-method-summary.ts b/webapp/src/app/core/modules/openapi/model/move-learn-method-summary.ts new file mode 100644 index 00000000..a325e7b0 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-learn-method-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveLearnMethodSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-meta-ailment-detail.ts b/webapp/src/app/core/modules/openapi/model/move-meta-ailment-detail.ts new file mode 100644 index 00000000..f335ab90 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-meta-ailment-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { MoveMetaAilmentName } from './move-meta-ailment-name'; + + +export interface MoveMetaAilmentDetail { + readonly id: number; + name: string; + moves: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-meta-ailment-name.ts b/webapp/src/app/core/modules/openapi/model/move-meta-ailment-name.ts new file mode 100644 index 00000000..411961f7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-meta-ailment-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveMetaAilmentName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-meta-ailment-summary.ts b/webapp/src/app/core/modules/openapi/model/move-meta-ailment-summary.ts new file mode 100644 index 00000000..21b1fbaf --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-meta-ailment-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveMetaAilmentSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-meta-category-description.ts b/webapp/src/app/core/modules/openapi/model/move-meta-category-description.ts new file mode 100644 index 00000000..f403a74b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-meta-category-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveMetaCategoryDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-meta-category-detail.ts b/webapp/src/app/core/modules/openapi/model/move-meta-category-detail.ts new file mode 100644 index 00000000..04ab1679 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-meta-category-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveMetaCategoryDescription } from './move-meta-category-description'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface MoveMetaCategoryDetail { + readonly id: number; + name: string; + descriptions: Array; + moves: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-meta-category-summary.ts b/webapp/src/app/core/modules/openapi/model/move-meta-category-summary.ts new file mode 100644 index 00000000..0c9c652b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-meta-category-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveMetaCategorySummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-meta.ts b/webapp/src/app/core/modules/openapi/model/move-meta.ts new file mode 100644 index 00000000..731d19a2 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-meta.ts @@ -0,0 +1,30 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveMetaCategorySummary } from './move-meta-category-summary'; +import { MoveMetaAilmentSummary } from './move-meta-ailment-summary'; + + +export interface MoveMeta { + ailment: MoveMetaAilmentSummary; + category: MoveMetaCategorySummary; + min_hits?: number | null; + max_hits?: number | null; + min_turns?: number | null; + max_turns?: number | null; + drain?: number | null; + healing?: number | null; + crit_rate?: number | null; + ailment_chance?: number | null; + flinch_chance?: number | null; + stat_chance?: number | null; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-name.ts b/webapp/src/app/core/modules/openapi/model/move-name.ts new file mode 100644 index 00000000..beda00b3 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-summary.ts b/webapp/src/app/core/modules/openapi/model/move-summary.ts new file mode 100644 index 00000000..05935f28 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-target-description.ts b/webapp/src/app/core/modules/openapi/model/move-target-description.ts new file mode 100644 index 00000000..2ac376c6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-target-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveTargetDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-target-detail.ts b/webapp/src/app/core/modules/openapi/model/move-target-detail.ts new file mode 100644 index 00000000..5a911e67 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-target-detail.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveTargetDescription } from './move-target-description'; +import { MoveSummary } from './move-summary'; +import { MoveTargetName } from './move-target-name'; + + +export interface MoveTargetDetail { + readonly id: number; + name: string; + descriptions: Array; + moves: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-target-name.ts b/webapp/src/app/core/modules/openapi/model/move-target-name.ts new file mode 100644 index 00000000..5c62a084 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-target-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface MoveTargetName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/move-target-summary.ts b/webapp/src/app/core/modules/openapi/model/move-target-summary.ts new file mode 100644 index 00000000..02e9ed51 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/move-target-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface MoveTargetSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/nature-battle-style-preference.ts b/webapp/src/app/core/modules/openapi/model/nature-battle-style-preference.ts new file mode 100644 index 00000000..cc3c6172 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/nature-battle-style-preference.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveBattleStyleSummary } from './move-battle-style-summary'; + + +export interface NatureBattleStylePreference { + low_hp_preference: number; + high_hp_preference: number; + move_battle_style: MoveBattleStyleSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/nature-detail-pokeathlon-stat-changes-inner.ts b/webapp/src/app/core/modules/openapi/model/nature-detail-pokeathlon-stat-changes-inner.ts new file mode 100644 index 00000000..9ff83fa7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/nature-detail-pokeathlon-stat-changes-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface NatureDetailPokeathlonStatChangesInner { + max_change: number; + pokeathlon_stat: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/nature-detail.ts b/webapp/src/app/core/modules/openapi/model/nature-detail.ts new file mode 100644 index 00000000..da12dde6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/nature-detail.ts @@ -0,0 +1,32 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { StatSummary } from './stat-summary'; +import { BerrySummary } from './berry-summary'; +import { NatureBattleStylePreference } from './nature-battle-style-preference'; +import { NatureDetailPokeathlonStatChangesInner } from './nature-detail-pokeathlon-stat-changes-inner'; +import { BerryFlavorSummary } from './berry-flavor-summary'; +import { NatureName } from './nature-name'; + + +export interface NatureDetail { + readonly id: number; + name: string; + decreased_stat: StatSummary; + increased_stat: StatSummary; + likes_flavor: BerryFlavorSummary; + hates_flavor: BerryFlavorSummary; + berries: Array; + pokeathlon_stat_changes: Array; + move_battle_style_preferences: Array; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/nature-name.ts b/webapp/src/app/core/modules/openapi/model/nature-name.ts new file mode 100644 index 00000000..38ab12b6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/nature-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface NatureName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/nature-summary.ts b/webapp/src/app/core/modules/openapi/model/nature-summary.ts new file mode 100644 index 00000000..1e794837 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/nature-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface NatureSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-ability-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-ability-summary-list.ts new file mode 100644 index 00000000..afa303c3 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-ability-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilitySummary } from './ability-summary'; + + +export interface PaginatedAbilitySummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-berry-firmness-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-berry-firmness-summary-list.ts new file mode 100644 index 00000000..8790972d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-berry-firmness-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryFirmnessSummary } from './berry-firmness-summary'; + + +export interface PaginatedBerryFirmnessSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-berry-flavor-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-berry-flavor-summary-list.ts new file mode 100644 index 00000000..64ed884b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-berry-flavor-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerryFlavorSummary } from './berry-flavor-summary'; + + +export interface PaginatedBerryFlavorSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-berry-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-berry-summary-list.ts new file mode 100644 index 00000000..d4ac03d4 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-berry-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { BerrySummary } from './berry-summary'; + + +export interface PaginatedBerrySummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-characteristic-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-characteristic-summary-list.ts new file mode 100644 index 00000000..eef9f469 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-characteristic-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { CharacteristicSummary } from './characteristic-summary'; + + +export interface PaginatedCharacteristicSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-contest-effect-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-contest-effect-summary-list.ts new file mode 100644 index 00000000..740594ec --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-contest-effect-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ContestEffectSummary } from './contest-effect-summary'; + + +export interface PaginatedContestEffectSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-contest-type-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-contest-type-summary-list.ts new file mode 100644 index 00000000..ddca4b15 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-contest-type-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ContestTypeSummary } from './contest-type-summary'; + + +export interface PaginatedContestTypeSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-egg-group-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-egg-group-summary-list.ts new file mode 100644 index 00000000..cc42a3d5 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-egg-group-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EggGroupSummary } from './egg-group-summary'; + + +export interface PaginatedEggGroupSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-summary-list.ts new file mode 100644 index 00000000..1091bc4a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EncounterConditionSummary } from './encounter-condition-summary'; + + +export interface PaginatedEncounterConditionSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-value-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-value-summary-list.ts new file mode 100644 index 00000000..5e3f5cbd --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-encounter-condition-value-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EncounterConditionValueSummary } from './encounter-condition-value-summary'; + + +export interface PaginatedEncounterConditionValueSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-encounter-method-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-encounter-method-summary-list.ts new file mode 100644 index 00000000..abd8954d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-encounter-method-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EncounterMethodSummary } from './encounter-method-summary'; + + +export interface PaginatedEncounterMethodSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-evolution-chain-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-evolution-chain-summary-list.ts new file mode 100644 index 00000000..f08a1101 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-evolution-chain-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EvolutionChainSummary } from './evolution-chain-summary'; + + +export interface PaginatedEvolutionChainSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-evolution-trigger-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-evolution-trigger-summary-list.ts new file mode 100644 index 00000000..80449eac --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-evolution-trigger-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { EvolutionTriggerSummary } from './evolution-trigger-summary'; + + +export interface PaginatedEvolutionTriggerSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-gender-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-gender-summary-list.ts new file mode 100644 index 00000000..8cac8c56 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-gender-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { GenderSummary } from './gender-summary'; + + +export interface PaginatedGenderSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-generation-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-generation-summary-list.ts new file mode 100644 index 00000000..56062563 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-generation-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { GenerationSummary } from './generation-summary'; + + +export interface PaginatedGenerationSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-growth-rate-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-growth-rate-summary-list.ts new file mode 100644 index 00000000..969446a2 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-growth-rate-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { GrowthRateSummary } from './growth-rate-summary'; + + +export interface PaginatedGrowthRateSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-item-attribute-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-item-attribute-summary-list.ts new file mode 100644 index 00000000..37798679 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-item-attribute-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemAttributeSummary } from './item-attribute-summary'; + + +export interface PaginatedItemAttributeSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-item-category-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-item-category-summary-list.ts new file mode 100644 index 00000000..f58997c7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-item-category-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemCategorySummary } from './item-category-summary'; + + +export interface PaginatedItemCategorySummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-item-fling-effect-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-item-fling-effect-summary-list.ts new file mode 100644 index 00000000..98d7f35e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-item-fling-effect-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemFlingEffectSummary } from './item-fling-effect-summary'; + + +export interface PaginatedItemFlingEffectSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-item-pocket-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-item-pocket-summary-list.ts new file mode 100644 index 00000000..51c5ffb0 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-item-pocket-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemPocketSummary } from './item-pocket-summary'; + + +export interface PaginatedItemPocketSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-item-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-item-summary-list.ts new file mode 100644 index 00000000..c1a4a465 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-item-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { ItemSummary } from './item-summary'; + + +export interface PaginatedItemSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-language-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-language-summary-list.ts new file mode 100644 index 00000000..d3e74821 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-language-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PaginatedLanguageSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-location-area-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-location-area-summary-list.ts new file mode 100644 index 00000000..d0eddf70 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-location-area-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LocationAreaSummary } from './location-area-summary'; + + +export interface PaginatedLocationAreaSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-location-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-location-summary-list.ts new file mode 100644 index 00000000..8022e9a1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-location-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LocationSummary } from './location-summary'; + + +export interface PaginatedLocationSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-machine-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-machine-summary-list.ts new file mode 100644 index 00000000..067d5a6d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-machine-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MachineSummary } from './machine-summary'; + + +export interface PaginatedMachineSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-move-battle-style-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-move-battle-style-summary-list.ts new file mode 100644 index 00000000..4f56addf --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-move-battle-style-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveBattleStyleSummary } from './move-battle-style-summary'; + + +export interface PaginatedMoveBattleStyleSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-move-damage-class-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-move-damage-class-summary-list.ts new file mode 100644 index 00000000..a88cf585 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-move-damage-class-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveDamageClassSummary } from './move-damage-class-summary'; + + +export interface PaginatedMoveDamageClassSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-move-learn-method-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-move-learn-method-summary-list.ts new file mode 100644 index 00000000..d3af2c73 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-move-learn-method-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveLearnMethodSummary } from './move-learn-method-summary'; + + +export interface PaginatedMoveLearnMethodSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-move-meta-ailment-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-move-meta-ailment-summary-list.ts new file mode 100644 index 00000000..362a9102 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-move-meta-ailment-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveMetaAilmentSummary } from './move-meta-ailment-summary'; + + +export interface PaginatedMoveMetaAilmentSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-move-meta-category-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-move-meta-category-summary-list.ts new file mode 100644 index 00000000..33d6e9bb --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-move-meta-category-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveMetaCategorySummary } from './move-meta-category-summary'; + + +export interface PaginatedMoveMetaCategorySummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-move-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-move-summary-list.ts new file mode 100644 index 00000000..ba08ac57 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-move-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveSummary } from './move-summary'; + + +export interface PaginatedMoveSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-move-target-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-move-target-summary-list.ts new file mode 100644 index 00000000..4dc167c7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-move-target-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { MoveTargetSummary } from './move-target-summary'; + + +export interface PaginatedMoveTargetSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-nature-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-nature-summary-list.ts new file mode 100644 index 00000000..2b524ea2 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-nature-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { NatureSummary } from './nature-summary'; + + +export interface PaginatedNatureSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pal-park-area-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pal-park-area-summary-list.ts new file mode 100644 index 00000000..4276e823 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pal-park-area-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PalParkAreaSummary } from './pal-park-area-summary'; + + +export interface PaginatedPalParkAreaSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokeathlon-stat-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokeathlon-stat-summary-list.ts new file mode 100644 index 00000000..55460c43 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokeathlon-stat-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokeathlonStatSummary } from './pokeathlon-stat-summary'; + + +export interface PaginatedPokeathlonStatSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokedex-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokedex-summary-list.ts new file mode 100644 index 00000000..788a816d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokedex-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokedexSummary } from './pokedex-summary'; + + +export interface PaginatedPokedexSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokemon-color-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-color-summary-list.ts new file mode 100644 index 00000000..7fc1cc05 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-color-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonColorSummary } from './pokemon-color-summary'; + + +export interface PaginatedPokemonColorSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokemon-form-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-form-summary-list.ts new file mode 100644 index 00000000..cef34c7a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-form-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonFormSummary } from './pokemon-form-summary'; + + +export interface PaginatedPokemonFormSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokemon-habitat-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-habitat-summary-list.ts new file mode 100644 index 00000000..efd69b7f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-habitat-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonHabitatSummary } from './pokemon-habitat-summary'; + + +export interface PaginatedPokemonHabitatSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokemon-shape-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-shape-summary-list.ts new file mode 100644 index 00000000..f86995fb --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-shape-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonShapeSummary } from './pokemon-shape-summary'; + + +export interface PaginatedPokemonShapeSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokemon-species-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-species-summary-list.ts new file mode 100644 index 00000000..8c9dbc1f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-species-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonSpeciesSummary } from './pokemon-species-summary'; + + +export interface PaginatedPokemonSpeciesSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-pokemon-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-summary-list.ts new file mode 100644 index 00000000..d6538920 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-pokemon-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonSummary } from './pokemon-summary'; + + +export interface PaginatedPokemonSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-region-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-region-summary-list.ts new file mode 100644 index 00000000..3e5be2bb --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-region-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { RegionSummary } from './region-summary'; + + +export interface PaginatedRegionSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-stat-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-stat-summary-list.ts new file mode 100644 index 00000000..8eecf5ee --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-stat-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { StatSummary } from './stat-summary'; + + +export interface PaginatedStatSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-super-contest-effect-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-super-contest-effect-summary-list.ts new file mode 100644 index 00000000..ca07cc14 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-super-contest-effect-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { SuperContestEffectSummary } from './super-contest-effect-summary'; + + +export interface PaginatedSuperContestEffectSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-type-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-type-summary-list.ts new file mode 100644 index 00000000..56247d3a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-type-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { TypeSummary } from './type-summary'; + + +export interface PaginatedTypeSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-version-group-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-version-group-summary-list.ts new file mode 100644 index 00000000..a2ea3bbd --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-version-group-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionGroupSummary } from './version-group-summary'; + + +export interface PaginatedVersionGroupSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/paginated-version-summary-list.ts b/webapp/src/app/core/modules/openapi/model/paginated-version-summary-list.ts new file mode 100644 index 00000000..be504122 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/paginated-version-summary-list.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionSummary } from './version-summary'; + + +export interface PaginatedVersionSummaryList { + count?: number; + next?: string; + previous?: string; + results?: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pal-park-area-detail-pokemon-encounters-inner.ts b/webapp/src/app/core/modules/openapi/model/pal-park-area-detail-pokemon-encounters-inner.ts new file mode 100644 index 00000000..d3d94b37 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pal-park-area-detail-pokemon-encounters-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PalParkAreaDetailPokemonEncountersInner { + base_score: number; + pokemon_species: AbilityDetailPokemonInnerPokemon; + rate: number; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pal-park-area-detail.ts b/webapp/src/app/core/modules/openapi/model/pal-park-area-detail.ts new file mode 100644 index 00000000..14f4915c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pal-park-area-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PalParkAreaDetailPokemonEncountersInner } from './pal-park-area-detail-pokemon-encounters-inner'; +import { PalParkAreaName } from './pal-park-area-name'; + + +export interface PalParkAreaDetail { + readonly id: number; + name: string; + names: Array; + pokemon_encounters: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pal-park-area-name.ts b/webapp/src/app/core/modules/openapi/model/pal-park-area-name.ts new file mode 100644 index 00000000..3ddaedb9 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pal-park-area-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PalParkAreaName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pal-park-area-summary.ts b/webapp/src/app/core/modules/openapi/model/pal-park-area-summary.ts new file mode 100644 index 00000000..3d1c2d7a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pal-park-area-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PalParkAreaSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-decrease-inner.ts b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-decrease-inner.ts new file mode 100644 index 00000000..ff925791 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-decrease-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokeathlonStatDetailAffectingNaturesDecreaseInner { + max_change: number; + nature: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-increase-inner.ts b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-increase-inner.ts new file mode 100644 index 00000000..4753a4af --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures-increase-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokeathlonStatDetailAffectingNaturesIncreaseInner { + max_change: number; + nature: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures.ts b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures.ts new file mode 100644 index 00000000..2e9fd1d3 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail-affecting-natures.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokeathlonStatDetailAffectingNaturesDecreaseInner } from './pokeathlon-stat-detail-affecting-natures-decrease-inner'; +import { PokeathlonStatDetailAffectingNaturesIncreaseInner } from './pokeathlon-stat-detail-affecting-natures-increase-inner'; + + +export interface PokeathlonStatDetailAffectingNatures { + decrease: Array; + increase: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail.ts b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail.ts new file mode 100644 index 00000000..e54b5f6c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokeathlonStatDetailAffectingNatures } from './pokeathlon-stat-detail-affecting-natures'; +import { PokeathlonStatName } from './pokeathlon-stat-name'; + + +export interface PokeathlonStatDetail { + readonly id: number; + name: string; + affecting_natures: PokeathlonStatDetailAffectingNatures; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-name.ts b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-name.ts new file mode 100644 index 00000000..cb9e332f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PokeathlonStatName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-summary.ts b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-summary.ts new file mode 100644 index 00000000..40c01fc1 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokeathlon-stat-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokeathlonStatSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokedex-description.ts b/webapp/src/app/core/modules/openapi/model/pokedex-description.ts new file mode 100644 index 00000000..8ea2d211 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokedex-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PokedexDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokedex-detail-pokemon-entries-inner.ts b/webapp/src/app/core/modules/openapi/model/pokedex-detail-pokemon-entries-inner.ts new file mode 100644 index 00000000..4f1f120c --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokedex-detail-pokemon-entries-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokedexDetailPokemonEntriesInner { + entry_number: number; + pokemon_species: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokedex-detail.ts b/webapp/src/app/core/modules/openapi/model/pokedex-detail.ts new file mode 100644 index 00000000..0d6178ca --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokedex-detail.ts @@ -0,0 +1,29 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokedexName } from './pokedex-name'; +import { PokedexDescription } from './pokedex-description'; +import { PokedexDetailPokemonEntriesInner } from './pokedex-detail-pokemon-entries-inner'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { RegionSummary } from './region-summary'; + + +export interface PokedexDetail { + readonly id: number; + name: string; + is_main_series?: boolean; + descriptions: Array; + names: Array; + pokemon_entries: Array; + region: RegionSummary; + version_groups: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokedex-name.ts b/webapp/src/app/core/modules/openapi/model/pokedex-name.ts new file mode 100644 index 00000000..e0a192be --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokedex-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PokedexName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokedex-summary.ts b/webapp/src/app/core/modules/openapi/model/pokedex-summary.ts new file mode 100644 index 00000000..5d865f45 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokedex-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokedexSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-color-detail.ts b/webapp/src/app/core/modules/openapi/model/pokemon-color-detail.ts new file mode 100644 index 00000000..37d5cdd6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-color-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonColorName } from './pokemon-color-name'; +import { PokemonSpeciesSummary } from './pokemon-species-summary'; + + +export interface PokemonColorDetail { + readonly id: number; + name: string; + names: Array; + pokemon_species: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-color-name.ts b/webapp/src/app/core/modules/openapi/model/pokemon-color-name.ts new file mode 100644 index 00000000..cd5ac09a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-color-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PokemonColorName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-color-summary.ts b/webapp/src/app/core/modules/openapi/model/pokemon-color-summary.ts new file mode 100644 index 00000000..e417cbbc --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-color-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonColorSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-abilities-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-abilities-inner.ts new file mode 100644 index 00000000..e2dc52d8 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-abilities-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonDetailAbilitiesInner { + ability: AbilityDetailPokemonInnerPokemon; + is_hidden: boolean; + slot: number; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-cries.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-cries.ts new file mode 100644 index 00000000..a28160db --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-cries.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonDetailCries { + latest: string; + legacy: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-held-items.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-held-items.ts new file mode 100644 index 00000000..4f9f08e9 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-held-items.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { ItemDetailHeldByPokemonInnerVersionDetailsInner } from './item-detail-held-by-pokemon-inner-version-details-inner'; + + +export interface PokemonDetailHeldItems { + item: AbilityDetailPokemonInnerPokemon; + version_details: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner-version-group-details-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner-version-group-details-inner.ts new file mode 100644 index 00000000..4e0015fd --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner-version-group-details-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonDetailMovesInnerVersionGroupDetailsInner { + level_learned_at: number; + move_learn_method: AbilityDetailPokemonInnerPokemon; + version_group: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner.ts new file mode 100644 index 00000000..b490793b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-moves-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonDetailMovesInnerVersionGroupDetailsInner } from './pokemon-detail-moves-inner-version-group-details-inner'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonDetailMovesInner { + move: AbilityDetailPokemonInnerPokemon; + version_group_details: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-past-abilities-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-past-abilities-inner.ts new file mode 100644 index 00000000..2fd8a6ac --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-past-abilities-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { PokemonDetailAbilitiesInner } from './pokemon-detail-abilities-inner'; + + +export interface PokemonDetailPastAbilitiesInner { + abilities: Array; + generation: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-past-types-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-past-types-inner.ts new file mode 100644 index 00000000..939aac7f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-past-types-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonDetailTypesInner } from './pokemon-detail-types-inner'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonDetailPastTypesInner { + generation: AbilityDetailPokemonInnerPokemon; + types: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-sprites.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-sprites.ts new file mode 100644 index 00000000..ef6b214b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-sprites.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonDetailSprites { + [key: string]: string | any; + + + front_default?: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail-types-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail-types-inner.ts new file mode 100644 index 00000000..a60910b0 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail-types-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonDetailTypesInner { + slot: number; + type: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-detail.ts b/webapp/src/app/core/modules/openapi/model/pokemon-detail.ts new file mode 100644 index 00000000..20f0cb43 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-detail.ts @@ -0,0 +1,48 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonDetailPastAbilitiesInner } from './pokemon-detail-past-abilities-inner'; +import { PokemonStat } from './pokemon-stat'; +import { PokemonDetailCries } from './pokemon-detail-cries'; +import { PokemonGameIndex } from './pokemon-game-index'; +import { PokemonDetailHeldItems } from './pokemon-detail-held-items'; +import { PokemonDetailPastTypesInner } from './pokemon-detail-past-types-inner'; +import { PokemonDetailTypesInner } from './pokemon-detail-types-inner'; +import { PokemonDetailMovesInner } from './pokemon-detail-moves-inner'; +import { PokemonDetailSprites } from './pokemon-detail-sprites'; +import { PokemonFormSummary } from './pokemon-form-summary'; +import { PokemonSpeciesSummary } from './pokemon-species-summary'; +import { PokemonDetailAbilitiesInner } from './pokemon-detail-abilities-inner'; + + +export interface PokemonDetail { + readonly id: number; + name: string; + base_experience?: number | null; + height?: number | null; + is_default?: boolean; + order?: number | null; + weight?: number | null; + abilities: Array; + past_abilities: Array; + forms: Array; + game_indices: Array; + held_items: PokemonDetailHeldItems; + readonly location_area_encounters: string; + moves: Array; + species: PokemonSpeciesSummary; + sprites: PokemonDetailSprites; + cries: PokemonDetailCries; + stats: Array; + types: Array; + past_types: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-dex-entry.ts b/webapp/src/app/core/modules/openapi/model/pokemon-dex-entry.ts new file mode 100644 index 00000000..80fabdab --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-dex-entry.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokedexSummary } from './pokedex-summary'; + + +export interface PokemonDexEntry { + entry_number: number; + pokedex: PokedexSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-location-area.ts b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-location-area.ts new file mode 100644 index 00000000..ed393be4 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-location-area.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonEncountersRetrieve200ResponseInnerLocationArea { + name: string; + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-condition-values-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-condition-values-inner.ts new file mode 100644 index 00000000..da410b9b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-condition-values-inner.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerEncounterDetailsInnerConditionValuesInner { + name: string; + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-method.ts b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-method.ts new file mode 100644 index 00000000..be685887 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-method.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerEncounterDetailsInnerMethod { + name: string; + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner.ts new file mode 100644 index 00000000..ba75cc9e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner.ts @@ -0,0 +1,23 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerEncounterDetailsInnerConditionValuesInner } from './pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-condition-values-inner'; +import { PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerEncounterDetailsInnerMethod } from './pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner-method'; + + +export interface PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerEncounterDetailsInner { + chance: number; + condition_values: Array; + max_level: number; + method: PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerEncounterDetailsInnerMethod; + min_level: number; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-version.ts b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-version.ts new file mode 100644 index 00000000..a599dd1b --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner-version.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerVersion { + name: string; + url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner.ts new file mode 100644 index 00000000..6368973f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner-version-details-inner.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerEncounterDetailsInner } from './pokemon-encounters-retrieve200-response-inner-version-details-inner-encounter-details-inner'; +import { PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerVersion } from './pokemon-encounters-retrieve200-response-inner-version-details-inner-version'; + + +export interface PokemonEncountersRetrieve200ResponseInnerVersionDetailsInner { + encounter_details: Array; + max_chance: number; + version: PokemonEncountersRetrieve200ResponseInnerVersionDetailsInnerVersion; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner.ts new file mode 100644 index 00000000..70474cbc --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-encounters-retrieve200-response-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonEncountersRetrieve200ResponseInnerLocationArea } from './pokemon-encounters-retrieve200-response-inner-location-area'; +import { PokemonEncountersRetrieve200ResponseInnerVersionDetailsInner } from './pokemon-encounters-retrieve200-response-inner-version-details-inner'; + + +export interface PokemonEncountersRetrieve200ResponseInner { + location_area: PokemonEncountersRetrieve200ResponseInnerLocationArea; + version_details: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-form-detail-form-names-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-form-detail-form-names-inner.ts new file mode 100644 index 00000000..06e198db --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-form-detail-form-names-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonFormDetailFormNamesInner { + language: AbilityDetailPokemonInnerPokemon; + name: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-form-detail-sprites.ts b/webapp/src/app/core/modules/openapi/model/pokemon-form-detail-sprites.ts new file mode 100644 index 00000000..79808147 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-form-detail-sprites.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonFormDetailSprites { + [key: string]: string | any; + + + _default?: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-form-detail.ts b/webapp/src/app/core/modules/openapi/model/pokemon-form-detail.ts new file mode 100644 index 00000000..d22ed954 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-form-detail.ts @@ -0,0 +1,35 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionGroupSummary } from './version-group-summary'; +import { PokemonFormDetailFormNamesInner } from './pokemon-form-detail-form-names-inner'; +import { PokemonSummary } from './pokemon-summary'; +import { PokemonFormDetailSprites } from './pokemon-form-detail-sprites'; +import { PokemonDetailTypesInner } from './pokemon-detail-types-inner'; + + +export interface PokemonFormDetail { + readonly id: number; + name: string; + order?: number | null; + form_order?: number | null; + is_default?: boolean; + is_battle_only?: boolean; + is_mega?: boolean; + form_name: string; + pokemon: PokemonSummary; + sprites: PokemonFormDetailSprites; + version_group: VersionGroupSummary; + form_names: Array; + names: Array; + types: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-form-summary.ts b/webapp/src/app/core/modules/openapi/model/pokemon-form-summary.ts new file mode 100644 index 00000000..48fcac2e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-form-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonFormSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-game-index.ts b/webapp/src/app/core/modules/openapi/model/pokemon-game-index.ts new file mode 100644 index 00000000..174ddd38 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-game-index.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionSummary } from './version-summary'; + + +export interface PokemonGameIndex { + game_index: number; + version: VersionSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-habitat-detail.ts b/webapp/src/app/core/modules/openapi/model/pokemon-habitat-detail.ts new file mode 100644 index 00000000..136ae517 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-habitat-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonHabitatName } from './pokemon-habitat-name'; +import { PokemonSpeciesSummary } from './pokemon-species-summary'; + + +export interface PokemonHabitatDetail { + readonly id: number; + name: string; + names: Array; + pokemon_species: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-habitat-name.ts b/webapp/src/app/core/modules/openapi/model/pokemon-habitat-name.ts new file mode 100644 index 00000000..f3e8fbbe --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-habitat-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PokemonHabitatName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-habitat-summary.ts b/webapp/src/app/core/modules/openapi/model/pokemon-habitat-summary.ts new file mode 100644 index 00000000..0bffd453 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-habitat-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonHabitatSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-awesome-names-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-awesome-names-inner.ts new file mode 100644 index 00000000..30ee6a27 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-awesome-names-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonShapeDetailAwesomeNamesInner { + awesome_name: string; + language: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-names-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-names-inner.ts new file mode 100644 index 00000000..e1a8a2a7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail-names-inner.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonShapeDetailNamesInner { + url: string; + name: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail.ts b/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail.ts new file mode 100644 index 00000000..07e312a6 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-shape-detail.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonShapeDetailAwesomeNamesInner } from './pokemon-shape-detail-awesome-names-inner'; +import { PokemonSpeciesSummary } from './pokemon-species-summary'; +import { PokemonShapeDetailNamesInner } from './pokemon-shape-detail-names-inner'; + + +export interface PokemonShapeDetail { + readonly id: number; + name: string; + awesome_names: Array; + names: Array; + pokemon_species: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-shape-summary.ts b/webapp/src/app/core/modules/openapi/model/pokemon-shape-summary.ts new file mode 100644 index 00000000..38ce0c03 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-shape-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonShapeSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-species-description.ts b/webapp/src/app/core/modules/openapi/model/pokemon-species-description.ts new file mode 100644 index 00000000..5370cea8 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-species-description.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface PokemonSpeciesDescription { + description?: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-genera-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-genera-inner.ts new file mode 100644 index 00000000..e5d89411 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-genera-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonSpeciesDetailGeneraInner { + genus: string; + language: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-pal-park-encounters-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-pal-park-encounters-inner.ts new file mode 100644 index 00000000..25124c5e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-pal-park-encounters-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonSpeciesDetailPalParkEncountersInner { + area: AbilityDetailPokemonInnerPokemon; + base_score: number; + rate: number; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-varieties-inner.ts b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-varieties-inner.ts new file mode 100644 index 00000000..535af2b7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail-varieties-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface PokemonSpeciesDetailVarietiesInner { + is_default: boolean; + pokemon: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-species-detail.ts b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail.ts new file mode 100644 index 00000000..a52f52bd --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-species-detail.ts @@ -0,0 +1,58 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { PokemonSpeciesDetailPalParkEncountersInner } from './pokemon-species-detail-pal-park-encounters-inner'; +import { PokemonSpeciesDetailVarietiesInner } from './pokemon-species-detail-varieties-inner'; +import { GenerationSummary } from './generation-summary'; +import { PokemonFormDetailFormNamesInner } from './pokemon-form-detail-form-names-inner'; +import { PokemonSpeciesDetailGeneraInner } from './pokemon-species-detail-genera-inner'; +import { PokemonSpeciesDescription } from './pokemon-species-description'; +import { PokemonDexEntry } from './pokemon-dex-entry'; +import { PokemonSpeciesFlavorText } from './pokemon-species-flavor-text'; +import { PokemonColorSummary } from './pokemon-color-summary'; +import { PokemonShapeSummary } from './pokemon-shape-summary'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { GrowthRateSummary } from './growth-rate-summary'; +import { PokemonHabitatSummary } from './pokemon-habitat-summary'; +import { EvolutionChainSummary } from './evolution-chain-summary'; +import { PokemonSpeciesSummary } from './pokemon-species-summary'; + + +export interface PokemonSpeciesDetail { + readonly id: number; + name: string; + order?: number | null; + gender_rate?: number | null; + capture_rate?: number | null; + base_happiness?: number | null; + is_baby?: boolean; + is_legendary?: boolean; + is_mythical?: boolean; + hatch_counter?: number | null; + has_gender_differences?: boolean; + forms_switchable?: boolean; + growth_rate: GrowthRateSummary; + pokedex_numbers: Array; + egg_groups: Array; + color: PokemonColorSummary; + shape: PokemonShapeSummary; + evolves_from_species: PokemonSpeciesSummary; + evolution_chain: EvolutionChainSummary; + habitat: PokemonHabitatSummary; + generation: GenerationSummary; + names: Array; + pal_park_encounters: Array; + form_descriptions: Array; + flavor_text_entries: Array; + genera: Array; + varieties: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-species-flavor-text.ts b/webapp/src/app/core/modules/openapi/model/pokemon-species-flavor-text.ts new file mode 100644 index 00000000..411d1fd7 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-species-flavor-text.ts @@ -0,0 +1,21 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; +import { VersionSummary } from './version-summary'; + + +export interface PokemonSpeciesFlavorText { + flavor_text: string; + language: LanguageSummary; + version: VersionSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-species-summary.ts b/webapp/src/app/core/modules/openapi/model/pokemon-species-summary.ts new file mode 100644 index 00000000..e34ea840 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-species-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonSpeciesSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-stat.ts b/webapp/src/app/core/modules/openapi/model/pokemon-stat.ts new file mode 100644 index 00000000..e3e88d97 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-stat.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { StatSummary } from './stat-summary'; + + +export interface PokemonStat { + base_stat: number; + effort: number; + stat: StatSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/pokemon-summary.ts b/webapp/src/app/core/modules/openapi/model/pokemon-summary.ts new file mode 100644 index 00000000..7cddbf55 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/pokemon-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface PokemonSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/region-detail.ts b/webapp/src/app/core/modules/openapi/model/region-detail.ts new file mode 100644 index 00000000..4e161bed --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/region-detail.ts @@ -0,0 +1,28 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { RegionName } from './region-name'; +import { LocationSummary } from './location-summary'; +import { GenerationSummary } from './generation-summary'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; +import { PokedexSummary } from './pokedex-summary'; + + +export interface RegionDetail { + readonly id: number; + name: string; + locations: Array; + readonly main_generation: GenerationSummary; + names: Array; + pokedexes: Array; + version_groups: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/region-name.ts b/webapp/src/app/core/modules/openapi/model/region-name.ts new file mode 100644 index 00000000..0abad482 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/region-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface RegionName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/region-summary.ts b/webapp/src/app/core/modules/openapi/model/region-summary.ts new file mode 100644 index 00000000..a5cc016e --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/region-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface RegionSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves-increase-inner.ts b/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves-increase-inner.ts new file mode 100644 index 00000000..026f2fd5 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves-increase-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface StatDetailAffectingMovesIncreaseInner { + change: number; + move: AbilityDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves.ts b/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves.ts new file mode 100644 index 00000000..999e526f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-moves.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { StatDetailAffectingMovesIncreaseInner } from './stat-detail-affecting-moves-increase-inner'; + + +export interface StatDetailAffectingMoves { + increase: Array; + decrease: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-natures.ts b/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-natures.ts new file mode 100644 index 00000000..d92017b9 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/stat-detail-affecting-natures.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface StatDetailAffectingNatures { + increase: Array; + decrease: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/stat-detail.ts b/webapp/src/app/core/modules/openapi/model/stat-detail.ts new file mode 100644 index 00000000..25e016b9 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/stat-detail.ts @@ -0,0 +1,30 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { CharacteristicSummary } from './characteristic-summary'; +import { MoveDamageClassSummary } from './move-damage-class-summary'; +import { StatName } from './stat-name'; +import { StatDetailAffectingNatures } from './stat-detail-affecting-natures'; +import { StatDetailAffectingMoves } from './stat-detail-affecting-moves'; + + +export interface StatDetail { + readonly id: number; + name: string; + game_index: number; + is_battle_only?: boolean; + affecting_moves: StatDetailAffectingMoves; + affecting_natures: StatDetailAffectingNatures; + characteristics: Array; + move_damage_class: MoveDamageClassSummary; + names: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/stat-name.ts b/webapp/src/app/core/modules/openapi/model/stat-name.ts new file mode 100644 index 00000000..7c984c7a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/stat-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface StatName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/stat-summary.ts b/webapp/src/app/core/modules/openapi/model/stat-summary.ts new file mode 100644 index 00000000..f64d0e83 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/stat-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface StatSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/super-contest-effect-detail.ts b/webapp/src/app/core/modules/openapi/model/super-contest-effect-detail.ts new file mode 100644 index 00000000..577d6203 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/super-contest-effect-detail.ts @@ -0,0 +1,22 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { SuperContestEffectFlavorText } from './super-contest-effect-flavor-text'; +import { MoveSummary } from './move-summary'; + + +export interface SuperContestEffectDetail { + readonly id: number; + appeal: number; + flavor_text_entries: Array; + moves: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/super-contest-effect-flavor-text.ts b/webapp/src/app/core/modules/openapi/model/super-contest-effect-flavor-text.ts new file mode 100644 index 00000000..542b4a90 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/super-contest-effect-flavor-text.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface SuperContestEffectFlavorText { + flavor_text: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/super-contest-effect-summary.ts b/webapp/src/app/core/modules/openapi/model/super-contest-effect-summary.ts new file mode 100644 index 00000000..a750641f --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/super-contest-effect-summary.ts @@ -0,0 +1,17 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface SuperContestEffectSummary { + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-detail-damage-relations.ts b/webapp/src/app/core/modules/openapi/model/type-detail-damage-relations.ts new file mode 100644 index 00000000..221cee31 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-detail-damage-relations.ts @@ -0,0 +1,23 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface TypeDetailDamageRelations { + no_damage_to: Array; + half_damage_to: Array; + double_damage_to: Array; + no_damage_from: Array; + half_damage_from: Array; + double_damage_from: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner-damage-relations.ts b/webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner-damage-relations.ts new file mode 100644 index 00000000..1de6fb13 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner-damage-relations.ts @@ -0,0 +1,23 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface TypeDetailPastDamageRelationsInnerDamageRelations { + no_damage_to: Array; + half_damage_to: Array; + double_damage_to: Array; + no_damage_from: Array; + half_damage_from: Array; + double_damage_from: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner.ts b/webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner.ts new file mode 100644 index 00000000..9d56df2a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-detail-past-damage-relations-inner.ts @@ -0,0 +1,20 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { TypeDetailPastDamageRelationsInnerDamageRelations } from './type-detail-past-damage-relations-inner-damage-relations'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface TypeDetailPastDamageRelationsInner { + generation: AbilityDetailPokemonInnerPokemon; + damage_relations: TypeDetailPastDamageRelationsInnerDamageRelations; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner-pokemon.ts b/webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner-pokemon.ts new file mode 100644 index 00000000..6d22d9e3 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner-pokemon.ts @@ -0,0 +1,24 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface TypeDetailPokemonInnerPokemon { + /** + * The name of the pokemon + */ + name?: string; + /** + * The URL to get more information about the pokemon + */ + url?: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner.ts b/webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner.ts new file mode 100644 index 00000000..b0af6c72 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-detail-pokemon-inner.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { TypeDetailPokemonInnerPokemon } from './type-detail-pokemon-inner-pokemon'; + + +export interface TypeDetailPokemonInner { + slot?: number; + pokemon?: TypeDetailPokemonInnerPokemon; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-detail.ts b/webapp/src/app/core/modules/openapi/model/type-detail.ts new file mode 100644 index 00000000..b1246556 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-detail.ts @@ -0,0 +1,37 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { TypeDetailDamageRelations } from './type-detail-damage-relations'; +import { TypeGameIndex } from './type-game-index'; +import { MoveDamageClassSummary } from './move-damage-class-summary'; +import { MoveSummary } from './move-summary'; +import { AbilityName } from './ability-name'; +import { GenerationSummary } from './generation-summary'; +import { TypeDetailPastDamageRelationsInner } from './type-detail-past-damage-relations-inner'; +import { TypeDetailPokemonInner } from './type-detail-pokemon-inner'; + + +/** + * Serializer for the Type resource + */ +export interface TypeDetail { + readonly id: number; + name: string; + damage_relations: TypeDetailDamageRelations; + past_damage_relations: Array; + game_indices: Array; + generation: GenerationSummary; + move_damage_class: MoveDamageClassSummary; + names: Array; + pokemon: Array; + moves: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-game-index.ts b/webapp/src/app/core/modules/openapi/model/type-game-index.ts new file mode 100644 index 00000000..239dc272 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-game-index.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { GenerationSummary } from './generation-summary'; + + +export interface TypeGameIndex { + game_index: number; + generation: GenerationSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/type-summary.ts b/webapp/src/app/core/modules/openapi/model/type-summary.ts new file mode 100644 index 00000000..122cd2d0 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/type-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface TypeSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/version-detail.ts b/webapp/src/app/core/modules/openapi/model/version-detail.ts new file mode 100644 index 00000000..9c31c0da --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/version-detail.ts @@ -0,0 +1,25 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { VersionGroupSummary } from './version-group-summary'; +import { VersionName } from './version-name'; + + +/** + * Should have a link to Version Group info but the Circular dependency and compilation order fight eachother and I\'m not sure how to add anything other than a hyperlink + */ +export interface VersionDetail { + readonly id: number; + name: string; + names: Array; + version_group: VersionGroupSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/version-group-detail.ts b/webapp/src/app/core/modules/openapi/model/version-group-detail.ts new file mode 100644 index 00000000..b2d58f23 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/version-group-detail.ts @@ -0,0 +1,27 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { GenerationSummary } from './generation-summary'; +import { VersionSummary } from './version-summary'; +import { AbilityDetailPokemonInnerPokemon } from './ability-detail-pokemon-inner-pokemon'; + + +export interface VersionGroupDetail { + readonly id: number; + name: string; + order?: number | null; + generation: GenerationSummary; + move_learn_methods: Array; + pokedexes: Array; + regions: Array; + versions: Array; +} + diff --git a/webapp/src/app/core/modules/openapi/model/version-group-summary.ts b/webapp/src/app/core/modules/openapi/model/version-group-summary.ts new file mode 100644 index 00000000..e1795669 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/version-group-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface VersionGroupSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/model/version-name.ts b/webapp/src/app/core/modules/openapi/model/version-name.ts new file mode 100644 index 00000000..a91944ce --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/version-name.ts @@ -0,0 +1,19 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ +import { LanguageSummary } from './language-summary'; + + +export interface VersionName { + name: string; + language: LanguageSummary; +} + diff --git a/webapp/src/app/core/modules/openapi/model/version-summary.ts b/webapp/src/app/core/modules/openapi/model/version-summary.ts new file mode 100644 index 00000000..1d41e47d --- /dev/null +++ b/webapp/src/app/core/modules/openapi/model/version-summary.ts @@ -0,0 +1,18 @@ +/** + * PokéAPI + * All the Pokémon data you\'ll ever need in one place, easily accessible through a modern free open-source RESTful API. ## What is this? This is a full RESTful API linked to an extensive database detailing everything about the Pokémon main game series. We\'ve covered everything from Pokémon to Berry Flavors. ## Where do I start? We have awesome [documentation](https://pokeapi.co/docs/v2) on how to use this API. It takes minutes to get started. This API will always be publicly available and will never require any extensive setup process to consume. Created by [**Paul Hallett**(]https://github.com/phalt) and other [**PokéAPI contributors***](https://github.com/PokeAPI/pokeapi#contributing) around the world. Pokémon and Pokémon character names are trademarks of Nintendo. + * + * The version of the OpenAPI document: 2.7.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + + +export interface VersionSummary { + name: string; + readonly url: string; +} + diff --git a/webapp/src/app/core/modules/openapi/param.ts b/webapp/src/app/core/modules/openapi/param.ts new file mode 100644 index 00000000..78a2d20a --- /dev/null +++ b/webapp/src/app/core/modules/openapi/param.ts @@ -0,0 +1,69 @@ +/** + * Standard parameter styles defined by OpenAPI spec + */ +export type StandardParamStyle = + | 'matrix' + | 'label' + | 'form' + | 'simple' + | 'spaceDelimited' + | 'pipeDelimited' + | 'deepObject' + ; + +/** + * The OpenAPI standard {@link StandardParamStyle}s may be extended by custom styles by the user. + */ +export type ParamStyle = StandardParamStyle | string; + +/** + * Standard parameter locations defined by OpenAPI spec + */ +export type ParamLocation = 'query' | 'header' | 'path' | 'cookie'; + +/** + * Standard types as defined in OpenAPI Specification: Data Types + */ +export type StandardDataType = + | "integer" + | "number" + | "boolean" + | "string" + | "object" + | "array" + ; + +/** + * Standard {@link DataType}s plus your own types/classes. + */ +export type DataType = StandardDataType | string; + +/** + * Standard formats as defined in OpenAPI Specification: Data Types + */ +export type StandardDataFormat = + | "int32" + | "int64" + | "float" + | "double" + | "byte" + | "binary" + | "date" + | "date-time" + | "password" + ; + +export type DataFormat = StandardDataFormat | string; + +/** + * The parameter to encode. + */ +export interface Param { + name: string; + value: unknown; + in: ParamLocation; + style: ParamStyle, + explode: boolean; + dataType: DataType; + dataFormat: DataFormat | undefined; +} diff --git a/webapp/src/app/core/modules/openapi/variables.ts b/webapp/src/app/core/modules/openapi/variables.ts new file mode 100644 index 00000000..6fe58549 --- /dev/null +++ b/webapp/src/app/core/modules/openapi/variables.ts @@ -0,0 +1,9 @@ +import { InjectionToken } from '@angular/core'; + +export const BASE_PATH = new InjectionToken('basePath'); +export const COLLECTION_FORMATS = { + 'csv': ',', + 'tsv': ' ', + 'ssv': ' ', + 'pipes': '|' +} From 1d16d76337348d132846d63f5e37856e6df3d252 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Mon, 15 Jul 2024 15:13:59 +0200 Subject: [PATCH 07/12] add a example counter using signals --- webapp/src/app/app.component.html | 5 +- webapp/src/app/app.component.ts | 4 +- .../example/counter/counter.component.html | 17 +++++ .../app/example/counter/counter.component.ts | 63 +++++++++++++++++++ webapp/src/app/example/counter/counter.ts | 26 ++++++++ .../hello-world/hello-world.component.html | 1 - .../app/hello-world/hello-world.component.ts | 10 --- 7 files changed, 112 insertions(+), 14 deletions(-) create mode 100644 webapp/src/app/example/counter/counter.component.html create mode 100644 webapp/src/app/example/counter/counter.component.ts create mode 100644 webapp/src/app/example/counter/counter.ts delete mode 100644 webapp/src/app/hello-world/hello-world.component.html delete mode 100644 webapp/src/app/hello-world/hello-world.component.ts diff --git a/webapp/src/app/app.component.html b/webapp/src/app/app.component.html index fbd3fbea..6113238a 100644 --- a/webapp/src/app/app.component.html +++ b/webapp/src/app/app.component.html @@ -2,6 +2,9 @@

Header

- +
+ + +
\ No newline at end of file diff --git a/webapp/src/app/app.component.ts b/webapp/src/app/app.component.ts index a99e9987..c6d0066d 100644 --- a/webapp/src/app/app.component.ts +++ b/webapp/src/app/app.component.ts @@ -1,11 +1,11 @@ import { Component } from '@angular/core'; import { RouterOutlet } from '@angular/router'; -import { HelloWorldComponent } from './hello-world/hello-world.component'; +import { CounterComponent } from './example/counter/counter.component'; @Component({ selector: 'app-root', standalone: true, - imports: [RouterOutlet, HelloWorldComponent], + imports: [RouterOutlet, CounterComponent], templateUrl: './app.component.html', styles: [], }) diff --git a/webapp/src/app/example/counter/counter.component.html b/webapp/src/app/example/counter/counter.component.html new file mode 100644 index 00000000..146af5b1 --- /dev/null +++ b/webapp/src/app/example/counter/counter.component.html @@ -0,0 +1,17 @@ +
+

Counter Title: {{title()}}

+

Value: {{counter()}}

+

HexValue: {{hexCounter()}}

+ +

History

+
+ @for (item of counterHistory(); track item.dec) { + {{ item.dec }} + } +
+
\ No newline at end of file diff --git a/webapp/src/app/example/counter/counter.component.ts b/webapp/src/app/example/counter/counter.component.ts new file mode 100644 index 00000000..9b648704 --- /dev/null +++ b/webapp/src/app/example/counter/counter.component.ts @@ -0,0 +1,63 @@ +import { Component, computed, effect, input, signal } from '@angular/core'; +import { counter } from './counter'; + +interface CounterHistoryEntry { + dec: number; + hex: string; +} + +@Component({ + selector: 'counter', + standalone: true, + templateUrl: './counter.component.html', +}) +export class CounterComponent { + // we put all our application data inside signals! -> most optimal change detection and re-rendering possible + + // Input signal `input` without required is also possible but then it is `string | undefined` + title = input.required(); + byCount = input(1); + + counter = counter; // We can share signals imported from file + + hexCounter = computed(() => { + // Pitfall: conditional logic inside computed + // When calling computed initially the dependency signal has to be called, otherwise it will not work + return this.counter().toString(16); + }) + + counterHistory = signal([{ dec: 0, hex: "0" }]) + + constructor() { + console.log(`counter value: ${this.counter()}`); + + // `effect`s goes in constructor (?) + // `effectRef` is not necessary, only if needed + // Runs once when the effect is declared to collect dependencies, and again when they change + const effectRef = effect((onCleanup) => { + const currentCount = this.counter(); + const currentHexCount = this.hexCounter(); + + console.log(`current values: ${currentCount}, ${currentHexCount}`); + + // By default we cannot change signals within an `effect` -> would cause an infinite loop + + onCleanup(() => { + console.log('Perform cleanup action here'); + }) + }) + + // effectRef.destroy() at any time! Usually not necessary + + // Readonly Example: (for when to expose something that should not be changed by someone else) + // readonly counter = this.counterSignal.asReadonly(); + } + + increment() { + console.log('Updating counter...'); + this.counter.update(counter => counter + this.byCount()); + + // Update values of a signal only through Signals API, e.g.`set()` and `update()`, not directly (i.e. `push()`) + this.counterHistory.update(history => [...history, { dec: this.counter(), hex: this.hexCounter() }]) + } +} diff --git a/webapp/src/app/example/counter/counter.ts b/webapp/src/app/example/counter/counter.ts new file mode 100644 index 00000000..a16ed0a6 --- /dev/null +++ b/webapp/src/app/example/counter/counter.ts @@ -0,0 +1,26 @@ +import { signal } from "@angular/core"; + +export const counter = signal(0); + +// While global state is possible, this is a good alternative: +// @Injectable({ +// providedIn: "root", +// }) +// export class CounterService { +// +// // this is the private writeable signal +// private counterSignal = signal(0); +// +// // this is the public read-only signal +// readonly counter = this.counterSignal.asReadonly(); +// +// constructor() { +// // inject any dependencies you need here +// } +// +// // anyone needing to modify the signal +// // needs to do so in a controlled way +// incrementCounter() { +// this.counterSignal.update((val) => val + 1); +// } +// } \ No newline at end of file diff --git a/webapp/src/app/hello-world/hello-world.component.html b/webapp/src/app/hello-world/hello-world.component.html deleted file mode 100644 index b6707154..00000000 --- a/webapp/src/app/hello-world/hello-world.component.html +++ /dev/null @@ -1 +0,0 @@ -

hello-world works!

diff --git a/webapp/src/app/hello-world/hello-world.component.ts b/webapp/src/app/hello-world/hello-world.component.ts deleted file mode 100644 index 643266c7..00000000 --- a/webapp/src/app/hello-world/hello-world.component.ts +++ /dev/null @@ -1,10 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector: 'hello-world', - standalone: true, - templateUrl: './hello-world.component.html', -}) -export class HelloWorldComponent { - -} From c5b781c10815e8261469774741b2f1e6e28ab986 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Tue, 16 Jul 2024 19:22:41 +0200 Subject: [PATCH 08/12] delete api client first --- webapp/package-lock.json | 122 +++++++++++++++++++++++++++++++++++++-- webapp/package.json | 3 +- 2 files changed, 118 insertions(+), 7 deletions(-) diff --git a/webapp/package-lock.json b/webapp/package-lock.json index de6fb0c2..56d78024 100644 --- a/webapp/package-lock.json +++ b/webapp/package-lock.json @@ -33,6 +33,7 @@ "karma-coverage": "2.2.1", "karma-jasmine": "5.1.0", "karma-jasmine-html-reporter": "2.1.0", + "rimraf": "^6.0.1", "typescript": "5.5.3" } }, @@ -7559,6 +7560,22 @@ "node": ">=8" } }, + "node_modules/karma/node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dev": true, + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, "node_modules/karma/node_modules/source-map": { "version": "0.6.1", "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", @@ -10225,16 +10242,109 @@ "dev": true }, "node_modules/rimraf": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", - "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", - "deprecated": "Rimraf versions prior to v4 are no longer supported", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-6.0.1.tgz", + "integrity": "sha512-9dkvaxAsk/xNXSJzMgFqqMCuFgt2+KsOFek3TMLfo8NCPfWpBmqwyNn5Y+NX56QUYfCtsyhF3ayiboEoUmJk/A==", "dev": true, "dependencies": { - "glob": "^7.1.3" + "glob": "^11.0.0", + "package-json-from-dist": "^1.0.0" }, "bin": { - "rimraf": "bin.js" + "rimraf": "dist/esm/bin.mjs" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rimraf/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/rimraf/node_modules/glob": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-11.0.0.tgz", + "integrity": "sha512-9UiX/Bl6J2yaBbxKoEBRm4Cipxgok8kQYcOPEhScPwebu2I0HoQOuYdIO6S3hLuWoZgpDpwQZMzTFxgpkyT76g==", + "dev": true, + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^4.0.1", + "minimatch": "^10.0.0", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^2.0.0" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rimraf/node_modules/jackspeak": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-4.0.1.tgz", + "integrity": "sha512-cub8rahkh0Q/bw1+GxP7aeSe29hHHn2V4m29nnDlvCdlgU+3UGxkZp7Z53jLUdpX3jdTO0nJZUDl3xvbWc2Xog==", + "dev": true, + "dependencies": { + "@isaacs/cliui": "^8.0.2" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + }, + "optionalDependencies": { + "@pkgjs/parseargs": "^0.11.0" + } + }, + "node_modules/rimraf/node_modules/lru-cache": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-11.0.0.tgz", + "integrity": "sha512-Qv32eSV1RSCfhY3fpPE2GNZ8jgM9X7rdAfemLWqTUxwiyIC4jJ6Sy0fZ8H+oLWevO6i4/bizg7c8d8i6bxrzbA==", + "dev": true, + "engines": { + "node": "20 || >=22" + } + }, + "node_modules/rimraf/node_modules/minimatch": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.0.1.tgz", + "integrity": "sha512-ethXTt3SGGR+95gudmqJ1eNhRO7eGEGIgYA9vnPatK4/etz2MEVDno5GMCibdMTuBMyElzIlgxMna3K94XDIDQ==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": "20 || >=22" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rimraf/node_modules/path-scurry": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-2.0.0.tgz", + "integrity": "sha512-ypGJsmGtdXUOeM5u93TyeIEfEhM6s+ljAhrk5vAvSx8uyY/02OvrZnA0YNGUrPXfpJMgI1ODd3nwz8Npx4O4cg==", + "dev": true, + "dependencies": { + "lru-cache": "^11.0.0", + "minipass": "^7.1.2" + }, + "engines": { + "node": "20 || >=22" }, "funding": { "url": "https://github.com/sponsors/isaacs" diff --git a/webapp/package.json b/webapp/package.json index f38758b4..eff0cc87 100644 --- a/webapp/package.json +++ b/webapp/package.json @@ -7,7 +7,7 @@ "build": "ng build", "watch": "ng build --watch --configuration development", "test": "ng test", - "generate:api": "npx openapi-generator-cli generate -i ../server/openapi.yaml -g typescript-angular -o ./src/app/core/modules/openapi --additional-properties fileNaming=kebab-case,withInterfaces=true --generate-alias-as-model" + "generate:api": "rimraf ./src/app/core/modules/openapi && npx openapi-generator-cli generate -i ../server/openapi.yaml -g typescript-angular -o ./src/app/core/modules/openapi --additional-properties fileNaming=kebab-case,withInterfaces=true --generate-alias-as-model" }, "private": true, "dependencies": { @@ -36,6 +36,7 @@ "karma-coverage": "2.2.1", "karma-jasmine": "5.1.0", "karma-jasmine-html-reporter": "2.1.0", + "rimraf": "^6.0.1", "typescript": "5.5.3" } } From 0cbcb290395006aee7a1c96f5b0cb010120646a5 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Tue, 16 Jul 2024 19:28:55 +0200 Subject: [PATCH 09/12] add base path --- webapp/src/app/app.config.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/webapp/src/app/app.config.ts b/webapp/src/app/app.config.ts index 4b3c1318..b0a2799e 100644 --- a/webapp/src/app/app.config.ts +++ b/webapp/src/app/app.config.ts @@ -1,10 +1,12 @@ import { ApplicationConfig, provideExperimentalZonelessChangeDetection } from '@angular/core'; import { provideRouter } from '@angular/router'; import { routes } from './app.routes'; +import { BASE_PATH } from './core/modules/openapi'; export const appConfig: ApplicationConfig = { providers: [ + { provide: BASE_PATH, useValue: "https://pokeapi.co" }, provideExperimentalZonelessChangeDetection(), - provideRouter(routes) + provideRouter(routes), ] }; From 72f06d47325223a11d4de56902eb069a80c5089a Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Tue, 16 Jul 2024 19:32:19 +0200 Subject: [PATCH 10/12] add pokemon component and service --- webapp/src/app/example/pokemon/pokemon.component.html | 1 + webapp/src/app/example/pokemon/pokemon.component.ts | 11 +++++++++++ webapp/src/app/example/pokemon/pokemon.service.ts | 9 +++++++++ 3 files changed, 21 insertions(+) create mode 100644 webapp/src/app/example/pokemon/pokemon.component.html create mode 100644 webapp/src/app/example/pokemon/pokemon.component.ts create mode 100644 webapp/src/app/example/pokemon/pokemon.service.ts diff --git a/webapp/src/app/example/pokemon/pokemon.component.html b/webapp/src/app/example/pokemon/pokemon.component.html new file mode 100644 index 00000000..31d5e618 --- /dev/null +++ b/webapp/src/app/example/pokemon/pokemon.component.html @@ -0,0 +1 @@ +

pokemon works!

diff --git a/webapp/src/app/example/pokemon/pokemon.component.ts b/webapp/src/app/example/pokemon/pokemon.component.ts new file mode 100644 index 00000000..b983a739 --- /dev/null +++ b/webapp/src/app/example/pokemon/pokemon.component.ts @@ -0,0 +1,11 @@ +import { Component } from '@angular/core'; + +@Component({ + selector: 'pokemon', + standalone: true, + imports: [], + templateUrl: './pokemon.component.html' +}) +export class PokemonComponent { + +} diff --git a/webapp/src/app/example/pokemon/pokemon.service.ts b/webapp/src/app/example/pokemon/pokemon.service.ts new file mode 100644 index 00000000..bf912598 --- /dev/null +++ b/webapp/src/app/example/pokemon/pokemon.service.ts @@ -0,0 +1,9 @@ +import { Injectable } from '@angular/core'; + +@Injectable({ + providedIn: 'root' +}) +export class PokemonService { + + constructor() { } +} From 1b2b72b842bfd385dc39e935283caae75eee2d60 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Wed, 17 Jul 2024 13:55:40 +0200 Subject: [PATCH 11/12] add pokemon example --- webapp/package-lock.json | 55 +++++++++++++++++++ webapp/package.json | 2 + webapp/src/app/app.component.html | 1 + webapp/src/app/app.component.ts | 3 +- webapp/src/app/app.config.ts | 11 +++- .../example/pokemon/pokemon.component.html | 29 +++++++++- .../app/example/pokemon/pokemon.component.ts | 31 ++++++++++- .../app/example/pokemon/pokemon.service.ts | 9 --- webapp/tailwind.config.js | 2 +- 9 files changed, 126 insertions(+), 17 deletions(-) delete mode 100644 webapp/src/app/example/pokemon/pokemon.service.ts diff --git a/webapp/package-lock.json b/webapp/package-lock.json index 56d78024..28b5fc9c 100644 --- a/webapp/package-lock.json +++ b/webapp/package-lock.json @@ -16,6 +16,8 @@ "@angular/platform-browser": "18.1.0", "@angular/platform-browser-dynamic": "18.1.0", "@angular/router": "18.1.0", + "@tanstack/angular-query-devtools-experimental": "5.51.3", + "@tanstack/angular-query-experimental": "5.51.1", "autoprefixer": "10.4.19", "postcss": "8.4.39", "rxjs": "7.8.1", @@ -3404,6 +3406,59 @@ "integrity": "sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==", "dev": true }, + "node_modules/@tanstack/angular-query-devtools-experimental": { + "version": "5.51.3", + "resolved": "https://registry.npmjs.org/@tanstack/angular-query-devtools-experimental/-/angular-query-devtools-experimental-5.51.3.tgz", + "integrity": "sha512-dI5D31FgfrW2uqFUbsG9590LMPLyaHjB/JBR9X/4sZz2A7ki03ew78OEup6ZIGk7pbyWQ7oq4dUlKOsxyQxjmQ==", + "dependencies": { + "@tanstack/query-devtools": "5.51.1", + "tslib": "^2.6.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/tannerlinsley" + }, + "peerDependencies": { + "@angular/common": ">=16.0.0", + "@angular/core": ">=16.0.0", + "@tanstack/angular-query-experimental": "^5.51.3" + } + }, + "node_modules/@tanstack/angular-query-experimental": { + "version": "5.51.1", + "resolved": "https://registry.npmjs.org/@tanstack/angular-query-experimental/-/angular-query-experimental-5.51.1.tgz", + "integrity": "sha512-Vuxa8UlmDeMUpIhTtvcQYmrXoVlup3z6X4uF8PgV7QtAi3jvGYpto+ZxtzkrCFNcrAPe/yu0ng81p62h1eCYcA==", + "dependencies": { + "@tanstack/query-core": "5.51.1", + "tslib": "^2.6.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/tannerlinsley" + }, + "peerDependencies": { + "@angular/common": ">=16.0.0", + "@angular/core": ">=16.0.0" + } + }, + "node_modules/@tanstack/query-core": { + "version": "5.51.1", + "resolved": "https://registry.npmjs.org/@tanstack/query-core/-/query-core-5.51.1.tgz", + "integrity": "sha512-fJBMQMpo8/KSsWW5ratJR5+IFr7YNJ3K2kfP9l5XObYHsgfVy1w3FJUWU4FT2fj7+JMaEg33zOcNDBo0LMwHnw==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/tannerlinsley" + } + }, + "node_modules/@tanstack/query-devtools": { + "version": "5.51.1", + "resolved": "https://registry.npmjs.org/@tanstack/query-devtools/-/query-devtools-5.51.1.tgz", + "integrity": "sha512-rehG0WmL3EXER6MAI2uHQia/n0b5c3ZROohpYm7u3G7yg4q+HsfQy6nuAo6uy40NzHUe3FmnfWCZQ0Vb/3lE6g==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/tannerlinsley" + } + }, "node_modules/@tufjs/canonical-json": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/@tufjs/canonical-json/-/canonical-json-2.0.0.tgz", diff --git a/webapp/package.json b/webapp/package.json index eff0cc87..bb1be80a 100644 --- a/webapp/package.json +++ b/webapp/package.json @@ -19,6 +19,8 @@ "@angular/platform-browser": "18.1.0", "@angular/platform-browser-dynamic": "18.1.0", "@angular/router": "18.1.0", + "@tanstack/angular-query-devtools-experimental": "5.51.3", + "@tanstack/angular-query-experimental": "5.51.1", "autoprefixer": "10.4.19", "postcss": "8.4.39", "rxjs": "7.8.1", diff --git a/webapp/src/app/app.component.html b/webapp/src/app/app.component.html index 6113238a..53b75a57 100644 --- a/webapp/src/app/app.component.html +++ b/webapp/src/app/app.component.html @@ -6,5 +6,6 @@ + \ No newline at end of file diff --git a/webapp/src/app/app.component.ts b/webapp/src/app/app.component.ts index c6d0066d..12b9ddb8 100644 --- a/webapp/src/app/app.component.ts +++ b/webapp/src/app/app.component.ts @@ -1,11 +1,12 @@ import { Component } from '@angular/core'; import { RouterOutlet } from '@angular/router'; import { CounterComponent } from './example/counter/counter.component'; +import { PokemonComponent } from './example/pokemon/pokemon.component'; @Component({ selector: 'app-root', standalone: true, - imports: [RouterOutlet, CounterComponent], + imports: [RouterOutlet, CounterComponent, PokemonComponent], templateUrl: './app.component.html', styles: [], }) diff --git a/webapp/src/app/app.config.ts b/webapp/src/app/app.config.ts index b0a2799e..1bb8529d 100644 --- a/webapp/src/app/app.config.ts +++ b/webapp/src/app/app.config.ts @@ -1,12 +1,19 @@ import { ApplicationConfig, provideExperimentalZonelessChangeDetection } from '@angular/core'; import { provideRouter } from '@angular/router'; +import { provideHttpClient, withInterceptorsFromDi } from '@angular/common/http'; +import { + provideAngularQuery, + QueryClient, +} from '@tanstack/angular-query-experimental' import { routes } from './app.routes'; import { BASE_PATH } from './core/modules/openapi'; export const appConfig: ApplicationConfig = { providers: [ - { provide: BASE_PATH, useValue: "https://pokeapi.co" }, provideExperimentalZonelessChangeDetection(), provideRouter(routes), + provideAngularQuery(new QueryClient()), + { provide: BASE_PATH, useValue: "https://pokeapi.co" }, + provideHttpClient(withInterceptorsFromDi()) ] -}; +}; \ No newline at end of file diff --git a/webapp/src/app/example/pokemon/pokemon.component.html b/webapp/src/app/example/pokemon/pokemon.component.html index 31d5e618..71b0e57e 100644 --- a/webapp/src/app/example/pokemon/pokemon.component.html +++ b/webapp/src/app/example/pokemon/pokemon.component.html @@ -1 +1,28 @@ -

pokemon works!

+ +
+ + +
+ + +@if (query.isPending()) { + Loading... +} @else if (query.error()) { + An error has occurred: {{ query.error()?.message }} +} + +@if (query.data(); as pokemon) { +
+

ID: {{pokemon.id }}

+

Name: {{pokemon.name }}

+ @if (query.isFetching()) { +

Updating...

+ } +
+} + + \ No newline at end of file diff --git a/webapp/src/app/example/pokemon/pokemon.component.ts b/webapp/src/app/example/pokemon/pokemon.component.ts index b983a739..001fcc99 100644 --- a/webapp/src/app/example/pokemon/pokemon.component.ts +++ b/webapp/src/app/example/pokemon/pokemon.component.ts @@ -1,11 +1,36 @@ -import { Component } from '@angular/core'; +import { Component, inject, signal } from '@angular/core'; +import { PokemonService } from '../../core/modules/openapi'; +import { injectQuery, injectQueryClient } from '@tanstack/angular-query-experimental'; +import { AngularQueryDevtools } from '@tanstack/angular-query-devtools-experimental' +import { fromEvent, lastValueFrom } from 'rxjs'; @Component({ selector: 'pokemon', standalone: true, - imports: [], + imports: [AngularQueryDevtools], templateUrl: './pokemon.component.html' }) export class PokemonComponent { + #pokemonService = inject(PokemonService) + queryClient = injectQueryClient() -} + pokemonId = signal(0); + + query = injectQuery(() => ({ + enabled: this.pokemonId() > 0, + queryKey: ['pokemon', this.pokemonId()], + queryFn: async (context) => { + // Cancels the request when component is destroyed before the request finishes + const abort$ = fromEvent(context.signal, 'abort') + return lastValueFrom(this.#pokemonService.pokemonRetrieve(this.pokemonId().toString())) + }, + })) + + incrementId() { + this.pokemonId.update(id => id + 1); + } + + decrementId() { + this.pokemonId.update(id => id - 1); + } +} \ No newline at end of file diff --git a/webapp/src/app/example/pokemon/pokemon.service.ts b/webapp/src/app/example/pokemon/pokemon.service.ts deleted file mode 100644 index bf912598..00000000 --- a/webapp/src/app/example/pokemon/pokemon.service.ts +++ /dev/null @@ -1,9 +0,0 @@ -import { Injectable } from '@angular/core'; - -@Injectable({ - providedIn: 'root' -}) -export class PokemonService { - - constructor() { } -} diff --git a/webapp/tailwind.config.js b/webapp/tailwind.config.js index eeced4e2..6fd21460 100644 --- a/webapp/tailwind.config.js +++ b/webapp/tailwind.config.js @@ -1,6 +1,6 @@ /** @type {import('tailwindcss').Config} */ module.exports = { - content: ['./src/**/*.{html,ts}'], + content: [__dirname + '/src/**/*.{html,ts}'], theme: { extend: {}, }, From e6af41edb2ac3bf9137f28a8b8b0a1123d3e4322 Mon Sep 17 00:00:00 2001 From: "Felix T.J. Dietrich" Date: Thu, 18 Jul 2024 17:41:07 +0200 Subject: [PATCH 12/12] update client docs --- .gitignore | 1 + docs/dev/getting_started/angular_query.png | Bin 0 -> 69038 bytes docs/dev/getting_started/angular_query.puml | 37 ++++++ .../angular_wordmark_gradient.png | Bin 0 -> 122287 bytes docs/dev/getting_started/getting_started.rst | 111 ++++++++++++++++++ docs/dev/getting_started/openapi.png | Bin 0 -> 60150 bytes docs/dev/getting_started/tailwindcss.svg | 15 +++ docs/index.rst | 11 +- 8 files changed, 173 insertions(+), 2 deletions(-) create mode 100644 docs/dev/getting_started/angular_query.png create mode 100644 docs/dev/getting_started/angular_query.puml create mode 100644 docs/dev/getting_started/angular_wordmark_gradient.png create mode 100644 docs/dev/getting_started/getting_started.rst create mode 100644 docs/dev/getting_started/openapi.png create mode 100644 docs/dev/getting_started/tailwindcss.svg diff --git a/.gitignore b/.gitignore index 6456d84f..85b59caa 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,5 @@ .venv +.DS_Store # Byte-compiled / optimized / DLL files __pycache__/ diff --git a/docs/dev/getting_started/angular_query.png b/docs/dev/getting_started/angular_query.png new file mode 100644 index 0000000000000000000000000000000000000000..8b999813101dc8c6e25f6fa018535d41e44cad44 GIT binary patch literal 69038 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 Idle + +Idle : Query has data +Idle : fetchStatus = 'idle' +Idle -> Fetching : User initiates refetch + +Fetching : Query is fetching data +Fetching : fetchStatus = 'fetching' +Fetching --> Success : Data fetched successfully +Fetching --> Error : Data fetching failed +Fetching --> Paused : Network connection lost + +Success : Data is available +Success : status = 'success' +Success --> Fetching : Background refetch + +Error : Query encountered an error +Error : status = 'error' +Error --> Fetching : Retry fetch + +Paused : Fetching paused +Paused : fetchStatus = 'paused' +Paused --> Fetching : Network connection restored + +Fetching --> Pending : No data yet + +Pending : Query has no data +Pending : status = 'pending' +Pending : fetchStatus = 'fetching' +Pending ---> Error : Data fetching failed +Pending ---> Success : Data fetched successfully +Paused --> Pending : Network connection lost +@enduml \ No newline at end of file diff --git a/docs/dev/getting_started/angular_wordmark_gradient.png b/docs/dev/getting_started/angular_wordmark_gradient.png new file mode 100644 index 0000000000000000000000000000000000000000..e32da38673d2e5717dd1b434bfa38295aae99c28 GIT binary patch literal 122287 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

OG3S%~{?NJ5-$-QAUGwOXq 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

Ni*`F0AgUp<{6uzM-67L}XNdIrDHDyCB z1!ahlMrhvYz8=TH>uF&VcM?&7lrrS(FTw5P143>&Q|4r7)i`fKdneSkleS{;*VPG#tKsqIAJs-@I&ig$ zRiRe?g@S%ko(^}OpX{|-J3YUd)3HL#8?C>oO?R?qsg9n0yb05(TJA((pz~qIkHQ`~ z42_y8%Wx@#=y;RRP6oJsyFT&yoVP#VqQ6R#KYifP;EUBx$uuh_QDs2df2I__-1UNv z_AwkQfCPHLx|bIZ6c%=j+nS@v!Gdy?Y-%pSs=p^p*Bs1e!r`pbuw4aC!UOK<@X?=@ z;j;u;iCN_{3A=BM6T0OD&TZnEH-AigRRb%x12`J9sqUSCvO` ztvs^SiAS9;-$z8|ED*baZ|Chx`c*ggRytg-{E7)AF@qIw3blA=R>)bAmS~I{G^ID= z>Yv5=&;ZClKA2 zWJ;|4a_?F3?dh`Z3+)xX#|Sk#^6j8AkKQ_3@04doMUG{>eJ#av`TL#ltSiY6t*1I3Um1%(LKG zfECSLYH4U8SUQz|R;`yd23|OHEWKAQa;?pG=OZ}iaQpBdjHpUxVdieH9f~dSr*J`3 zT?|Zz$MP&|7hiCj=#%GJzynAVewW+JSxxUFndu7MVg>cWM-S1zs(uf7fBYf3!a@-V zQ7E3_lu?cXKpk|`{T!?*ZG^yrb*q-qBq5=RhBBJJqoSm-cOg4Gfgz3hgk=+d4VFZ% z;yI)jj*j=g-iwTSM;^FRdcf9?U#yK;fU^gz&g0z)BL z>-{z8i;V>|6hXu-=w!E!-Ui}HPyn7K*OPpTKMui=#z)myR(}UHUmoiFnKu4kLqPTcY=QXnAz;v-rKQTXxOkoUtYM_TX z4wICjBO-(%yBsr@-Cxvi<>qf3Gaa(thrg`y)RRn#QeEk0v!#gb zZmB{AtX{P97Amc7j+CkOb7ur`JUpP}^vl?Uw+Kgml0~FQn77Kb;yA^8@|;)9njjsu_m+3Gnxf~_ow$5!up^_(LT%PNxynBoaHie&WceL=1=@521V(D z+SL-yJP%kJq3*ubi61;|>Jd}fPZ1QWJo*n{^xAm&>siBqU4DNy^LJA+<^4Q(l){~e zd6a2)2(O_51{~ANH2}diTbB}_X`EiERotK1a3%I$Z&Y<+=Wz2?!^h=3|DOml z;(A}XFA%wJ33;Fy-PPqn1Q6@)`CZEWcDJn^L7!f z>HSbL_G35@=X@s{OSsN`Pcu0q_N8RAM*eKn4}(`@!2^@%z*ycH86T>f`k1r4Gz*f# ziN6WbWamG!cC~nsYzt*;$NLkN!D%jg>V_aT=lm@zrRj40Ak0UkOyGD9|6BayFB-Sg z@Jah?%EFk^F=h6*uI>kwfoGWE)Wp6~wjL$5fbR{mca%@jGN-OyR=2)lki2WBgC_0O zzr8SZB+jGe@@Au_QH!GC=C2|T21aYDPqvzPVr4WA1c&}?zrY;`0@nX^+T*zhE92}% z%cKb?E6_jVZ)=o)l<8w)V1?@LC!6$)#f@>VwF%*}Ip9`((= zORJ44FJo!Xp>_=qiLMKFv&%@FGgo0h;aK%X=PJHlw%r z?#f5$9*kJQbEAQW4p4-D+()}@wrt`b0{(rjE2!8WtgVMIfx43vL!jOm9XLdO&>?23_uXUoWS2QMf_>lPJoX37Y~oCIkw=6NWT`Y1MJR5`!n% zijgBN8BCGm%pu5{qgy#RAbArW-4Zu1{4 zN{1Bs#3T)u;O&)O9pB{aAQeu0<#l+xwU~Ij zjQv{3W;FIQ*yNw7q=Wxl*Mjo~2g>f!f?^D^Jr5u;DQx+@9nCv*^1UQRpU0Qlv0_x# zALO%nT#48Ni9vQ{iEIT30?Z25&W#XAnK@}Dy)HRiKUkni`!-qX140S_tfjf#T`kp? zKx0y!cbDg>AM1^mpU|3aG7eI9J-2?LB^w?)j6GM*Z5Ay`$zhf*PnREkM%S}1WyP$= z;aC+5e}s%90P~pQw=@IGT$W& z4$rBd)!%}qv+&2%6Q}Kr2Vq9RM7KUzA|!-Yx2C_s%-A8y8zDp2H>O4DP6y|6zl8Pw z@@o)?KC{lcqI8m`HVkPeXE&T}{T6+qH4hn;34&mJHm?5|M3axmGF_n^;miT#hVWfETwv}DZ z$`7`!Vr03ZnWq|J4-r@%9NFTQZ7j z?OyX39eS5rgHYGn_xa1QUy`r%H6uKqkGK6vS|61|Uu5aDw*D|R5xsr}ry<2&SlBY( zcOfNrUW%pkW?zew3}v!`Bv4}^vU{%7lxr_sB6Y!YRHaIPNnKn5NaZRRU@|Q^TdV8c zr5p;Ibpf1{X4@O95Z8H(x1pOAE)JnB_xfpskHajT+8H&CCmg&EK6N#E+{OCa7HPl+ z2v~I848KgY_qs7gNeZagcU_+g(D}3QZcVx^SIQ@O_`HND+D}qgLp=m- z!Y(CW5kcN}y*(UFcyzW$V`U&CHwQyem=51%9&U85@-mI}H}J822TymP3OAM1KpK5= zmsd-v;)t&$f)P?&sp$lK}gOa%OcFW-0oFo02t;oEH~FV~I zbRQw%vn4lvSB>sy+*QCk-;o-HMvqBO8SM_C9MFJ(mFP*OUE3(0DG#PQD~qw<@nQIW zSkP!kBI7i*t>oH*ct!`<$~fLdeC_(F5%FzO^xBTGAT(DgQl#K7 z5?#B3&=|8w|0Byr#ey>O+Q4g~MuA^eI|6Gah`!6<&74Mv{3%!a1Hk_ob2@wOPB+E& z7@=5!ktuD+OD)ayb3;|16LD19Ycr}GRvjIV?Yl1aiCut8ehy$CWPP0I=_q%WR<<4R zPrsyaDO^An95RWDO>$3RWQvVaLhBjU<_%j=!wEdpnMI)?4|Sm=hMMXllw<;w!&nZ~ ze%#wJrdgO3qy2*Vy-k7BZ|&9uI38TC?#<1 zfH7iA!E?_3$#fz>c$e62(%$yf(f-C@AbXzXq1 z|Kj?T#pE#Q>kR3Hr=^R)`qx_ahtn<+r4RESI#+d*|KB%lfTP>-@{L6w#cqkdFMVTu zd6eT9g{1r>RDaJRY%RD4?C2E)&aJQ`fdHvH>Qa(c)kjh~NT?ar{m8_*(5g#aGV(Y{ zTlc{`5`pj?phe;W_JzXm(9cSnNTaslOW+;cjlkOnOblQ~>eT!&G;>t72Y>kcDu+?Q zq1-r;@aL)d>y;zqXx&>I!SG}kDhFsYCoSB{hd2aVtvl0}*%tcTB*?_}Q4JBgqxy0j}e#B6r)w%yF^Y_MU7iKV~; za1(w<@f76gkg2%82f%^0#0kvZi6UOD` z8a{NPZi@{30c6)p#f|1- zBPTZPu27!7)C@U*S<(t@wLX7Js!yKSUd|EJuyy3V6)B#t51;Lw0E^D-aPa!?; zNeXWqbAdB%jQWDignD+LJbBu!=PB)X2$rek;X;1IqKMUz)U#N#o9*bTjnO7&w9iB=tELk|~lx||&mcz#2u<^oQ^EDO88oKG?+1~VZp z=x9bel&yDVA|QnW4Mn0ujtbViUgql^?v_Iay#YV;=tPT}5H-A34J7VW8xfS1+ z)A*z)=%;~8g^&4hJJk_dS~x@;nNv*sQbqm7%7A)x+;ZhuEm!6V5EZ&A=*m-w%K$is z@qIu~b*f_3M2oZwAUZ9zt=s8o59Pb%`%>#pJqF5JhMyx#RlGouCal1|C|oOxvMlCO z(8jdb1yZ_WmqeGBD*SduS$k`vt}fLBuhv_*Rg!svAxehm-@GU{Wk!4KQL-}K5{OYfl^V%0=O5!>7&Ke`oe@hwxmI? zVS!KDEmrbYTuG4*=%ZcZGkb#U;LC(AV(Y%V{nBE@H{O&yUlNMr!4Z;>^IWLq?_8}t zF-SONY3d8itA?f&?X2SNs~Gm2uNghH zDodF2`2FGVlx;0XDoL@qy<*gHQBkr`PnN%TJDqKXRtXE?$%A7){Pwp|uOHJ2z7k2y z0#37nx*;6mL#KuX??kMhCinugHaPuo)pi=st8VoC(lsd$AHN>YB@&s#3x5(MogX$x zHjc6@l&xRnAR>^dw5h74drAYkp-}@oxs>6YV6P~*18ILzZ23Gl_m+Odl6pOFvf*PGXor)9cEgsEhIc71lpxmnri;EjEu z*9e7(3Cka38HqJZ`NGlf=WQtJcY+u;2@SM@jDuH|ysUcM0rjc?Z*t(S%k7_2u^Nn= z7UeEjuyD)8&q}#ha#jX24SSW9sc)z1i|)1)L#o8Up;IN&iK5Tg+v?Uywnfgui6^D` zzex<-%NmH2`h-@jUfA+_6KR~Gdx5_xKLkSQb3}!bWB!8;a3nxmr|RxNPmvs5#r2QH z=T8MoFqpu8)mLI*WR*9ppI(04i9XK>EA1mXx}&l&Z={z+aq1+Ej9bNZs#ml(RNzk05Hb3++=%^k`i zdNwoy^4RUqOI_E))vg*r&;jAOW7e?|>hh-*SH%_Y&UhytR`;!p_9rS$`iIxu2k+;9 za-o4f;S$15s(dYtuP!sVZZ=^1<;xq-$rac*kuh?BvW+x!`!`IfBk#qUyu~W5(`b8T z0}RHLqZDOZ;=-BL%ffK}%vD$t9Q=KleI2@_cNHl$#|MQZ*%DaOZSAdR7BodcgX;U8 z{6bV(e`WCR3QUdnS>OXZx^Mc&82`b9vN?gw8#+@dGV^5dvE(EVWZ%e|`QBsoDrdTV zPvApbCD@3-8mBh@8b*P%7_8jqX-pp88{dZ7)%v>PqEW67{1#@UdCzF1E^+YAvia&M zFx?-&QbRrQG^MI=ou2CYd2EJdV&LiM>BTM8Zxj$i&0KQ@476xW z&qq{^1ZY8LA$?7Z>oX47_e3 zy(`B>UB+*`V2mCJrK%$)a+2*$X`1*>_yW}oEaK^XxgdRJutSFIc3X7ym)lA*WW~fM(w^tZ)1nQLI^0s?WB*FN7 zL&jxBcClLdypE^YR`u(3R9b#7!UDlZVBN%Fa-{GBNBf8;iJ#}ayB{t)=zCcpHiw4Q z%vaZ|5r&e;&>K(lBk(ceTpP&J4;|uWi$~R#l=?)zE}*1ZfcX-j3p(HTvua|Z>y0~> zK21aNTFX(_FaN=iQ4V%_$EWyZt^0Ixg-HXVy?O;RcP8GZxQ>{Kcm_d@i@%i$vpmVi z-Q4zi&N7>fP$n-&VB|Kd&fx~kC;T2iv5}{v$M*-}HCnp@$#bO(ZlXjg;V?#e|1|c0 z6C=A2iAOR+T10v**g=pVbht_-d&fzZ)WYO+anVxgnqK5*Id%=j+d&b=V6>u89RkNi zumokolH|31C@t%nt({^Vd#H%T#?=sQrrf8q9EyiJ2H8ei-~1u3FoJ%s|61z0@J&)i zHM2xd{4ZGjr!fjq9+Z7?u0(b6NmA)q5)Pf%Q;s3R?$^L!w$)O75jJUI)gb}o2T;oZ z`}Bx?c)nV_aUN7zN{If+rr>YTLfXajTMer`nvK2qc#{Wz8+lhh6Ao|== zX_3t)tG5M6csXoA!aJKDkX&rVE9JgZnI~H%dmDe)qfpId{}YKq(A`T|%=OzrydmED zE;D=|6j(Pn;P+n5lu~i)oo_5n?pYDggXrY!{>HUL$P<%2mJsv3|6Wg}ruB%tu6i#g z^auq~emaN_EuVRVK9`i1D%BH#C*VoS>Wj8refnfbO(&ml)|^#!)yjVJ7|Y=(hF(fI z1gdlw&JKZ67@-Waiy@Ko#t%M+5g%m)n6qx@w#|d^!&xzQGb)UNt7Q*zZ^O=OE)#S0 z{L`f??OLLc98pzSEX6{Ls;iPcZr}qX7ho>R*f{gk{ff(hQk77ji>6``9o&xWhH{z` z(7(OW#i2R?)0^uy2qNTQOD>$UtBdvWHv#B|^A5wE^dqdH1qB}-EIYICK{~cB`~Bk^ z_pv^xDf7o{R$osSTU{(eXL;*MLOdV}_Q#H*N7A~UVGyHsuvYmehBBFpbs}{#u8;kP zW3@l3EGysppA;G2_(_e#5%#tIkIX3Dv^Sp_lJ%=n{TatrQ#0y@m(+D@n4CM(fy8JK z=03K+<3qAP5l(wZmx9Oqk@lH(Tl)sOsw+hlNpTEB*BtECSK?X>P&RPaE;M0}j}u22 zN8P<4p;C`5&JH~Y6QA-yZsy2gy z6f2(;9o=Lqn+zO3fH3_CJbjak`mwy$h06md@nE}|mbhoXb)Mp9|4QbiMQX`PJDZyq z$S-0jD9@xgIrNMhYy=B^cq1U{xkuDJtjos;pr)P90>PsQf|RpOz7ThqgyS9k zt>a4rII4cm%h`9>qMJH@1cS3%(tqe=LjWuwW;oHN_qr8J$9b8N%X?`wv)eYl&KqW1 zfz8LiLg(-lEeov`VSVwlJU{30;JC-RPDB;C%U#GK%XzWSOr|?Nk7-ggc`#*~teeSd zpB=c6f>a*+OW2{QQ^~g!8AUDdFx%<|?G=ns(3;<=Lox#pDtqfH1JYk8P|-Alo`TBDAvnS87JRG(8GFP> z=}K;)3@p*jEmqCV_U!=)8qE_8zj8z&Jusl6IORD6%JD~8x>DtA=Ac3Cd6sV$ia3a$VWT5My;}u@|agqzMQzQRUK<3XX78WIU!r=-sgqq z^DZ<>%10gDg9b58Cy4>*|K}eHVTaa&1tvDNCo-#)^6Lq^(>4|W?x*Jp?c^=yYg6c0 zMC}^w=#c$y3&G4YtNT-QG3zXLP??E`<|XBK6!wS`p_N3;Zz}dy7xbKk(kTYMf1ZA! z1D;#D`l}MEO-Om3N)K&pp)v-Z8cIb*-;#{XHF#)`CEf1P$vRYM^W~i;+kz4<>ejCA zJ;|Tq*hS`8!)eB7X?EHu+#6Z;Xr_JTF7D<%obCAuM+!YE_h5viz-Nio#CcEMP>cFk z#FoomrVyg>=JQi=4>Ab^FmJt^;Gn_VIg@#{0jb~IA$ z7nl{`xP}9c5_)7u^Z`V?Df%g6HZK&iH07Zct&U%ZaRXY>Zwh>r27NgP9Z1y^i!*q3 zjOME?-{=s_3-ZRw#=1}G{(Z`gwaA4|+&&_;(Ny<0vfU~@$p2HjSr3Q(Bu_yH6%f>a z!7#aKns%$FfT7R3choAPAiszBH+~4UVj~ux?vE7IMc(sFn?Sv`ayh&6(cGXuJdI9liaDkC9jO4b`F+6Grfjf2s}=^q6ESI2>kkreb@Bs? z5K$Wd}=NkETt z2?_^lg*!#iqj-CoU+2u2It9b3&=+b30ofWVEC+b~T~_ELO?5T?8~|o*hA~oEvFonN z;XFM*I`KiV*Ho6l8_H;D&S;P0&{Fn28+N(|@&{#roy4*EyqZbiA%5A(*f1=b>QX`foZ>!d#!4} z_9BWR_qfY~dtceLIg=)MDaf;3W0CCai6o`Iygg%YKtO;LAoScCbI1bIJifVwL8?VB zx79dULoy?urH1VYVPf9`F067U^#lhW4nF1RY%`U{4;-g)x5^@~R<&aq0^3+qQovOKH`(vX| z!?#!AW@~Uh7@x%u149vWt~FeRwBb~pwMFQ0)u=n}crnqpSR;b`Z=1E+uY?J2_VzeQ z!B24_oL&;J23^EI8zWr5TJhh6QJhY~-mo%rE28`6EuO2C0c^IIS{74?YDn5B+p~$j zDZZ`SFy{}jVNGoAU0HDVqvu0ad|8jX>amuWXa9V4?He*K0!qf8CBgDi4O};MR}1Gg z6A(N`DKk;DWe}IJe=4E*xE&T&Tc#F#ysgT@X`@V@@Fxyx&)KR)tPf2+?(bAD^?ASS z1n-qlhn$NKnqwU))Lse7Fu*(@eYN z!2O+Q^kTPVQH2vVrKGcvpZ8Tf*cm$weI^Gy_utef8y>A<7LSN#65Li~p#vz;d>$)Z zFxXXB({}M~8pbCYG<=f_<5%CI3?I%-f{%eYg}#;{hki-AL3&m}#jfu^=Diyq52)gH z?`vC%6JU7)k1&Q!ZyJ|}gU}z(FR+gMOuJdo6 zt$n{by#rDK3v*uXN1JFQg;q2ro7|&rNs}16#j3F)OWPl8wZAp8b(%2;v9`N+)}2*T zkd2Y=awWRXGJR1NE?ssnxShBN0mEKe&dbZL-PdhsEk2E=F~*z~Tk`*Vpi=OG;!`)E zGn?p`^e$rrYNxRSs6E~`1lOqYKq0k1sN&De$%$FjnG00YExWYE_rX<()AF0#25>fi z4`Y01Fyfmqb8ql&W57u3vwo6~8I?VDtoiGg-))u6%z_v>+S|b5bLWmC9 z=U}4vzZ4~BA4;rAdSlb)!x~!_uoWLzk(HmO%}hCPeD{&vvXLv5`TI++sp@gT9QF!a ziMqruC0knczaKf%o_L8iE3v84dw3={Yj6r0#=j!%R3^UOl^R^~;kKg+5 z;Y{OIQ_`%LIVw-sUX9K>I3py`Lx;z8)lJgwb~jG)kdKE@V_|Xds%oc~C+?f-T2*@7 zb!Y%(guAx!JlQ6;``g$1er%;ShCQ(^(QE%G;=@@c+ZQ;uXe;A+L=@i?k&VVqvELATqX!xVFmPC%>*6zb> z8V%#$o`LA`Q_2PSx(l>Abx;NfdnBWe)wnXWYOvxw?}ctEykvRcTH-5>pkP`sdMUMp zCxe;B*B=7At>PM;6tw;T7g(poTs3^2e?0Pdi;cuA{h@+6QBl;8pY#7{`sTR2|L^@f zyJalfS}k+g%eHO1mR(DW%Pkv=%f_-@%XZzrSMSg7`%jPi&#u=w&*O6)dVska5~Qn7 zl|QPl;4Tr)9hRk*l}eEpo|PJxJYW_Zl6wU#LmY4eboPhGLkBp#YVjS5R?6h8tO4F zuqvruC5GGxZ}Bt``C&0Z6Re2+%Rx5Gv}?wP?jan7?C-(;vKMe!a8d=JDNZmmVq(Y- zv9#p*X~r{r|Fv7?o(FwA;&4ak@lm?2Hji>50OC_wk%07kkwP{L2nq@{kcyNSF8LN* zmbX>lx0S~(T3TpW$Zq%k9Ez04VW$c@^ z*C-HQIiJZw5yqDw2cR?40z^E|`Ku8|B6(y`PuwC)I^0pk2fAP7la?bn*{#I+^ZHpj zgJ?{0TOiFg9VB0H-DNVzKldmZH${%F8HrngQdwi>=5ogW?e1J%Udf7?id)m?8s{LC zhJT4IhHh;8n?Lc7p%86NNCM(XcPVQJIZ^Wb1(%y$(utk?i5q>~|LQt<_nJ&88w`oa zQYgUsXTBbJ1?OQsAQtz0_%I}bnoW8DZd(xgYx+$OTd|sL+#4t-r zdgjia;OKF33ON1_81(74h4n`+zKz>52mIS#EscT))S@kL32+^!o?aI^`)XlRGucH$nY+==iNb2LW zK`lQh7`kKN;KgjD$%7Us;$-DF`@&;7xoW~Us>OTg)Hd?-8adYF&IndXCJ7^9EFPeT z!<<&KrwUG7PN*bGhlmjU$cL5PPX2l1AHy6QmHuhfjeCLXt1y`8g zPTS@GG6EyI(SpCa00)owJx|*gY4Sgqs`tjpg{D4hHBQkcOHc0XZIpkv3Khcc8Kp>q z(p9>fqe^t4QwdetMfxu(L9boB_HPrUATOZEwfuIkj++E4wJilqQe!{>@I*Ix(FJ~U z+j2vE%)a3r9GQE?T9^;7^eoUng-6DDyzAE!TK43_`7Of_bCA~Omte4iJtTMg%{?ii|ruM6Gb+Ou@|Sc+#?sRlzR%fURR%FEY{ zGbP>6dLy~he{#3f$ayC^+H&Iz_t2LhsyO(l$jg*XT>dazwf?UW*=sB=G#$zQZ@`ET zlGx-{2msg%BvbjaV##mr%E~kX<41uVb5K6P%L`8mA=SLAAW*;a^LD^8&6&F0%%gWk zy)MKG9Gn|GGR>?F>z89ZOP1Ecpv1y9v0D?Aj$g*pnB&g|J_j3eUB@aLpC&7%P@}S2 z>dd}^^9!<`Jfbh7>8T{GthSp7h*y_JRH6&I-R7;EWPSi6gW zq4FTgtlKgD^@NKsHy+*NML|^cKMXi8c3AWN7^czb~iL1#`R@sv}GT zlpQ&D`*WZ_G3f1GZQCFOCIW?N6dcqLnFVVIeCh~&LVT5+>C*MID>xyA;~i1GS~qzh zKPGD+Q+xC*I@Wj9>_mu`LVf1jq`OuqoNc_`4rw?v@InWQ0xFJ?69MGg^|x381;DtD zO@r&xb1u^Ip9PqMt0_vt_G^P}A1*fPa8Zyk6kK=v*rS4X7WXd%nOfwe;@sTV$ZD|h&||N$ zdaLQjNP`my-K@;*CsK;i=#@8(S*-HJIo{4`M9By8SGQB8opPe!IKIGjC!MUPkgY;p zz`1XZGl?`<#Nn*tCq$33qnhHbm;VhEabZ)FaLPt`cH`TXk*dWX-L0t$_#h!UK7qix z5u63b&L0C9Bj(BgtaAlNn%}~Z(avuwFA^M-a!Z3^u3yBOQ^8e)uluz(BcX0u>=?-F zkBYsTPaZtiFr=J7f-q{6DJm%`WbaweHRlf7ZaejEhVY%-KTN9lINXS4)T?>(*}Hqhn?=O?T`I&diX(=VC{sAdv?fZY~SexNpp@j{fs1|e2f6>qHMoUetdJj zVXu%YjB~j?SrCj;ivR${gu%USPPh7FcNb%B9(~<=Xy&zlQ4W}CormmNhUqn~ePuaa zDMCD?8n{y#X}!_DKj_*bge)f=whl51vx~xe8E%UzM9fk4FV~)eh#i8c`8CV{^WFw3 zgq7^<8yj-wsiNU7xU>Rf&2;ekd_sOO~v(u~LF zBTN=JEYsl37eWdFC~|)?c)=V&pOP6sK-XhCgaZ&FCmxHrTDlKmHY}~Dp?jP{FSZuz z0Pe1>*7Z$=jFMyn_4XT&Bz0jT(Y5KX86+)_aW5}ad&m4^+}1xMkuK1b?(n-Q&R9jo z27U({CvR(ten{#=^1?0495dbsf#2$^MFV1L7+;@CZ=V0~DVDsu2(K?{!bG0c##ors zd^K`|QEZ)TpEsXa_DRf7@z1ptVKuJ878 zqVo}|dZM)P*EjPNp=rI^(akA~Rl%0$H@G}yXrjJMAH>Z(i_;RU0lF!BqYu(2!1xDJ z>uL`w`U(p>@3e-cp($xnng(llHOup@Z z&&a^&%oZkLfa^9b2UAsYee9|$$aSTtxZIlx*7DU#2NbAwU1x>kV|2q>VPC;jyumYPl_04cEN0$hJ@ zF5*sP;eVh3j~HY&pqIZ|X)k@+Y5QnIO#P*QUYWEOoANHYF>mp%?*b*%5@9U|F3B@P z11;y$(_9~3OgNRp2&pInf2DBMxaaQ<7X~f^f*qs4_&z!dc4g72`fOAwRkuW7A1?7Kg`4viuL#iSe$c-qWt@>BQ!`oKX|CZM70+vm12U9mp^2?fQjCij!V#|$D9D@kzN+7(rKKj| zZ_k?FB+~!niae|+5|<4RxXkYlbiJ8NoRnOk(O++VUYlHv&SRJuF=CE`1z6@RuV%0U z>ATXF17GY*mhk&z7~EbJn1_&aj|OzqPP3Z7UF9(*r89fFS|pqvESH>QgZPF?e~Pfl z8Bi@UqwA4zzdVuw>46%P&q3E8LK2smG;J18Ss;|5%r6Fi+Gg;T`%SXm#`--j__*}1 zAn?`mN>0FMgJI{s+i<@rEi2EUX$y`P7h2mkwzJ&#gh5e~b+6TZz095|_l{F8`Ym#& zi8!WTezHgIqXz5Vxs67$HqLC}!9#8~)I}MI>iq197ks_j-|*S%j_WY$ZWuS3!Mx~c zdMZgtO}J_FYxrA~Avwl^Im722M98KOkzjYr^_&Lwe}WvmCTmmp5c=q51xnx2^T?nN zIO4?WhhT9dhho!vbrAKRv-NLdw_&`h8kz&2V4Y6&{c|`_w68Wi5HQ$$S$K2e4wvhQ z+GOl+!48xI;A-RO5RPXr)#p@sM{U;b|vK+H!CfbMR(oXf)v zYyKmtv~LtjTr@LFP&zsC`pdLX^6$Oc1YcQ6RL(%%$Q`srm9Rozk@CRT$|Udu<5#d@ z;~azL$3OE(t0%!$7y%8<79d9h3w$zG3&%F>|S5BH-cyLn#CIxzF*bXDQR zdB972uYNmYrzyb)tRse2S>P;x*G!?Z6BdCD(1nqrHB@SbpU@juk^v;{?%Uiq|ZacTh**EJ{ij>2TdwVy#nTK_r&C|LaJ9h zXi3Esf!#5!roAGSCxiIA@>8Nx%iKgQ;_OFms}e#ovijJV5<#w(GjbVr1VDF+!B%G4 z=8jt&oT?=x+&X*gJocoK#oT+=ZFXo%%rPE2ElfZN5{XSyZ091)S5yBv-n36fZQhPm zvt-S7LPr+>iclz?Y$SZ3F5|Q#;K^0S9bAa#*Q6*QNh`IeEuBYn5zje4}ru5@pcNt@t?HW^oGA@y$zdt%QJ*sDd+4Ron&B~I;#n{)@Tc=zv(yUg~pv2Sl{cs|)4yvr9hBVNkL~grFn4u$eGKG}jc1wH3 zn?uZVcc}AS8TU_k=~cGwWtjH=5nxVpq6;|h-;ESl*jL-;_HcG}rwKM!(v>AGT-(BQ z!@n<%m8Ye}e9U!IQS zHW8q2pmWsPw8wvLu>u!-v&#Oe@wIfh;dt|?aYy|Vz<^`+%I0`1(?KRgc&Eol$PqEUOx-2eF?3s*;BELC4KN9|2 zzBV?uH6LDlnJ(GbUR!opLf<_QK3sr-Ag!jae4>?R9kbx2&t+ z{IXHV?FoOeE{?4_Aeae?`#MoPRga*Y_e~&t?rj^>*%JLrm3r}xX4!5hZOSRt0X}Gz z|NAmXIH{+%B2!yQY+4sL<(Q%IxWF&qvf7>S1PZ|aGyy|?i99_ryCsY^J@V4U8I6?x z(eh0V$I0Km&x#v_z+Kcy=`))eZ;?$rl9{M(N;AjnHGP<}jQ=-|8VAw4a67^ugHt;!BR;HXn0<|{_bRgtV2N}l=|K$4 z8_5?`J?M_4-El(Un|@~6%9*6%ku-M{0{KyD_Wzm`a4sFLLlNVkZ@eZ|Q66ss&k1fm zt|`_#zhTZ)^G;w+!*IXeCR z+Dy&0=#l__JVl=E8F9yNX|Z)3m#F2%lv+JY@c}33WED49tjjqM<9$+E*Pdkb$>GV2 z7_q0jl?nM0*+|^-Jw{7_vyiNirpRIS zfsFuqx97=8_0LpGh<}V#aS=U{8>uoLGj@MgAIU|5vCy>+%J`+I>FRnaQGq4i6X4y_ zOaSlJDHHmNH2s>yWkb!dJQE7YG_KxxmY4K=Z{46(!ydyz^Z-EJGc|xUqOh)nq_sAn z@#l*=zCO?Qlg5V&+~&qNH|Fdfdu$j#>VF(x{;i|s2AhR{#Gq0Ys;C?uVmKxJjJlSS zRFJ$B4P4|c46`3lPp8299B9_pxo$CA)>gklL@6}O60k}@ z|0|me5@mkJUVFbusba^i6%*kp)jt=uWE8sRSX*1%hG8KMTzZazia4FP{TXI-0dK(0 z!VtLSF@BL#iUNs_Dh~>lNi5;5LFEC9{Qp{41kH}%Eiu9d#J)iQB~#GU_~URu-2$xI zU?+2Ur!=_z>U?DRQssNTQLe3fnCy6Lx z!%kIQyqgJ2LXA_0SCzl_t`RwCxW&h{UA*x$z)ZmaYs-iyL6kH^g_ObN zvwXNPJHb^(c>)j2-RN|D?^Pcp1lNqm~Jm;_rKxdUqR%EEhMJX=wg&(p0eV zf$cMB4al94k|ufiID3 z(rH_w0UZvT8BC5py1(jgW_N5dHY?O)E~+vLCTk+C@V`7%Q$C`Ru(xQ zH7&z`z_NNeN?3=~c)A$dL99Q8b#WJbn)?|thW}adijKz*&`i!ujs&WSIdPZx57P_Z zmjkHqT@Yr#g2X25AZq}cK&*6UmHx=l(_JSCm;m5A2O#3r0k2L}ghRJI%UYR-=G$&N zb=+4yI8ui*VxsD#YuSZ?WbZjTRy<^O(1a4jgdpuKyj|Xyg#;p7JxfE~yy>U$qaD43 z5?%75k{b7tJVIHKxV{RZx3)UVf*GbjJG$yM_XD53sM~0}DF*WI0e$}6MiF0?pPQOL z>j~NN6Wg=HTjE5-NHydaDB2xZ(ox+qkX^_N>AZQl2N(#w7^dXUZq@iT)Cuh;e1@0^ zkPTemuosg#4TwFt%a(PWLjt7(rL$Rh;1Xw36<^%+Ein4}UV|AO?7yQU0}HyCCxxZ- zq4TrcgCb(?qZsntC`&u37)hM1h~v0ZHtma#ZecSxI2CgI=R@mF+f8|J^jLi~FVi9Z z>JNX@{`B#*lW!@6B-^um@pSH{2q#b3LISJ|{ROjr;?S+%Av4$0Y$H7)=_PQ1D%8li zXeTy4uW^NDod{Y9rEY&O)&PaJ%?0&3uYRN1ms9LC)62Y8AYTg}!x3~sK;jacu9)0Z zPYL(i&u)keMPY0|_2CSG0F~O4lyW28a0pji6;MtH^|=9OZBM$x^a6J6AQoZZSmzs5 zH^2s&{Pz%DC)-pbzU)M;`Tq4G6g@r`0N#D&xcS?LkJ6HZ=hwQy=X;Z%ZTdnUn|xpx z^?eu^@;}ur)2_%-cb?~)mi?c~*w9Hmzs(iO%yO5ZDMR3Qbc}UVPG<;Zv76xUb-?Aj z&1Mv<7%`1RitD%7OKPU<+8}@oVHJOK7`};;;W8~X=xpFhe3HC`S%mfEL1=lcwkq{D zn;rOz?C@tf1Ma2iQ%n%HsH1^SHR12BBRa@k(Hjz?$Js7gzb~6cibn@2mX|wYT7)0S z)sU_~Nc7IXKSl_36ZYsfoP2F__Nw}!WK~X!WDO7&u;pGa!p8758+3dUYO_F9j{7d; zZe%CmB7Mr5kNETNuX+pFQ143n+8-FfX)>-oVbuxZoECdWGbr#4vg6#QrK(6r6U)n*}Im-D$QiY6tVgPgqZ% zC>oYbrohlc`sJMwib5fjA{CjzQet|*9bYi|I8?Eda70y2-`VGs@zG*jkODAKmF_3> z*xdVspB%ne^*a^s?D-OD(HISY>A2f{PrOE*uk`HBfVE*!VtQ}E&l#9M&ApL6{;Q@T z@QAzRwuzVjDrH@j^GAl6;Ae-s)HNO&N^&onZxmh#EkBHjNnK7(CWOqc8<727x6=qB zW7$MC{1(fT+d8jO?KB7`x~PLbMQ9~IxYag>uVpkSeAXp_n`s2*dW}!-B7H(ksRIww zfs+N=G}+tZB;vm&DIspX`ea2^bxQU~e=&p&SR{xsY!=f>Ds22(k22V-$r1SA8(K8k z8@q@Yx|`V;c=6ci1DL0!O>JS`U%hPmyx95PIJ4su(nc=7&KhcT$Uxe_7x?_+teAIc z3e{P#RO?;5%B0lg|Dqmqm%OwVM>KvS!X5a2B`-M%mi+NrQI_Ew*|n`Yn0Z6H5A9t) zsTuQhSW6U5=~mP_ZYWYO;O?cvk^1`88wk8z;L)#4R^w*B)OeGynzSBCe^*6ZcI%+p z*GC+?6X<0?HC1R!35;FYa=r~Go7&HE%C+RWb7QKMXb&pDOTZn}BY$josObm|x}iF2 z@=ZQDw(ZN_d$&y#Mg9zBNxnM`C1f^oVv3)l;K~wXV7|B+{WPbLr3f7_yDICuf)IuS zlsC_&!P3$1a>m+YBi?|}S^M4cGSUI5mz-Ei+L8PZhucg8@mnxkxf=+2|18k}S!(LX zq)N^7h!aE3T6i9Np%NX&t~DO{f$SJGI|Jox5$5n28$fpzIccHi`?)}ibSfpj|_q`6$r z?|gR3ghcqH_PR&Av%W(X8e(Z%$k~mxaR5CUDqBz4_V_47gJOK#oGz`ci>T{}ae45b zjfKu32G302eNihzbCx}ES6R%W&y`^$0ks7}8LFpu4$bIy4OwFVIBN@g1wY&A3{$#g%Z_@rQo_0Do0Iu3V% zyaZePwu#RWWV`N2zI>k#5wdo@<7E?15xUoPK+lr>Z4<855{&uXMSvw}jN6M^BRShtV zrs4q$=RGz4i=XK=;&LRO{jbLD1c3_=punOMHX~B{W`m^;?N5A^7qk#E;#taZvMAKa zr`GiIX`JQGB z((K*n>Z>SET-`4-{MK_>@020Fx`U zSp!dLLeU7ZF13>JGEB@-;~6*kz%x1&^jYR{@+hZ=-*eH6k#~}oxX?(=&8RF3j3GbW z-)YeO_yOeq{v4@0d`@{`IRPvnioa^0=Hq+gi~@yl_RZa6=5i+x^zK<=mwv&rIytO^ z{UQzZn7K*i9R8AZ{aQt~_37L%(Y&CEn`CU@<`$XGEge*T=QYzZSrQin@|}H$*LK>7 z^d>)AO4sP{rxK#Y?*TsuMDcG`kWFqcLhHSr`#MCdDTKN8*B|ES-E8kG@CV?WxLu+T zI+t~&PgPr!Y^1U)lG8F zyu>8;U@#T1H)}K%(85h?As%$~xs<-slac%{+`Cqg>}CU2IRTu(tZp@F9Xx2`m`5(b zXJM?Ufx=lwsQEd5_VNn#=$qq7wWZJwjoPR|TQ}j-^1bW(O$pL=(Q^4|D83xo#>rp1 zQ{#U%S*Lo?l}jYfVPGl3TRbN{?#{jT4mZDC_4h}0r#ggUf5500|1oD^y}O|M(bVcY zUranDopZ5H3BS<~Po?G!Xy12lk{vfNY-nX6aO|U7Dku7VUPFuZ5E0E*W`efnpB870 zl!6fVI)9=UUxksK4fT#DKn5{I0tgM8x}*K-sUHpJzbI%T=v;u8Jpc4bOX*S3-GEa7 zPPmC%;TwbbFQ|@mOquLBnO~TFoao3m-ZVPfvIjesSQytQHoVYHr<1h@rnPjF`SqmI zkluADj)^eq(n87*Gk@1OQ}e1&R!W{0EJ|yn*4UdBS4Vx#G&h5MpEruxCHKcgq&k=S zN1;Uuvaa}Y@Fn~la!^gXp^xjX%Y0^9!s3-rypejnys4qS{J6aB{SX73|H}8;aKp&s zy%Hq{%qU+By)dt}$;;PMS}P5sC5_M~c6Y(Tk$X9N6cF^m&skUyIeD8z<=(c%+Ef&| z%;{5l1oK5E%=?3*!;Q4GaRz6vWtME%H18g{{R)T5LpvjWJeI#&lqh^Fj*+*C_{CUM0tN=~3h_*wB2gS60AOXCQXUKAbU~zaUWN+~B_) zo!j{RlpDKdJA$v~pW%^^J_JpNpaE`k7$B3Lt)g`KCjTpy>C|O_US2)2*Vl6Ly)dA| z;e%sj|E+4 z+ADQFM1L)0&4;NAp$#gGg1lJa#wbT z&{o8u%0opx8eH=`4M)dZv*cXEMug|7IOQM-%gE5{hp;V6h`E5ESO{Nl1L;wzE2P5C zUnb#4LoA8E`7tUVE1+$F?1(t$HxjFL6)w=Pc4R!UNjVGzDPil+I~?DxPwKxkWiIxf zs`mQus|T6^i^fZayN4xh5vKuwMh9MGIpkv8o_}$+zZA;46``{&_Uf@eKpVQh=#(m9 zl|QG%qsE1x!497pa^OTh%o;Lv`#6ipvzPvjcq^q9RD=0kB=RiRwcJBfeMa&mJw%~M zZbiH*=;Xi@AL)t0Kj8bKBG8tf}{PW=u#6FL@Tgm(VF+o?V zvvpJ|+Ylk+4#G$0ZqR@PfB3^J@(ms6yYm6Y9Ml}&+b7cWww|cTm70VJQjMU zl7;u+hYihs#K6F0hf)@^C-q^NfRdg@F2$Eq(zx2a8qc3empW3Q{He?~py|-3D>F6XI>Y@-(e$~Wj+bz*)>K#0 zcFq1u~c6Hx+@Fjk3JY6& zl`h9BQ7Rx8p_s!lPPBV_n~*~XqeBV|qHuJTtGDdRwKB4<)S&)c|4B5c#+YWWCC>Hj zOPw8X?&UgH9=umuZyna#c zg@-WdnCTEP&$d+T*&GLKqpY2n(C|VA7N~PMJ>c~XaB9D?4EvdWU;dEJ>ULcl!O2x4 z_ZCb{2@Fb$?|NoT#M@nE*2-AWQ~Hu7*0)Hqmo4`zCA@laL0S5x*yu+O7H5m^~$wqtob z4~XrykE|rk^64WFRU-@gQyRH~uM3UH%kl@378$NsLbt<-12b}77ay44XE#tyz&iP~ zN&Z2);O*G|-~~sTkbmgCjp}sflUUV0q9(%^Z=~ z+kWBaD6?$Vvd$QboY0KU-lpr$p1UqmZkX9>#&!W9;(R%kU^MgH-6H#I6?ZM!AOxc9 zn=GQXdwu~llTWPg`P1JLV7}U{ceygwXR??RGX47M(t|6aw0;anktk!Giy=*~-+VsR z6ghH6)2f2~70pJ?^pOJl;{ClPiWu~UD$dFNe`%eIyNl8bttJ`cm1k=>z8yoPp+pd_dVE9P7IfZSd5zOf)=vw z;JXe-2tH<58tbX$n}dhgb+=RuZ8s0ncex?EKt0FYmiX<%{Y8hp2p#<*LOny%`rQZa zBp%u7LSz?dHT}k#2A&K)l#XYS$1oyCIv7j}%=C_U$oRx~s)_IBM18CHf z@01R9I5o@Go*xY9fYF#oakwDQbY;sqxR4@8z9Vh!kM&%YG-39T)mI-tJe<6X=N zz?}6gr~U|rN?`H$0GkX^dsGx%pc zr@97Xt``9$yLx1N@$qC6&*C1va1Az1NI*l`9fJ7?N5HGj-zFtOKdKUo+bK>{-P@?b zMr+l*zGGp~qbA+G`QK3MoalJKJ z(g=It(u46&XO6IjqMMQzK4A#H<`Tj#!g3>gqm-@vzgd8%c4rR`)jD^Zopl#fV-ZR~ zZd7%ZB&j=o!>6;2;@1PCbp{;-v-JD8ceSInJ*@!3%Bu)S!FI=8puD7+!iFT-o;O>G zwH3~x?K@|VyHO`3YbVr9$g=Onc@2Ua?Jg2EPS*9unz6L_`3pGb*IkM$P58y#V}pHdamD%a^#nKS}=CB>Lw@b{aN_13o8C`YUFr3VUaA-A*nfsWVW_- zl>t!IGqhzU0>9-4I1SKH1h(ftAdlu3l3OqGl8VAgUrXK{^M`YTX?;LIlR4=|9VVrU|pPFFxeq~8oTLu*CjG@f%c zDvwtF1U@b9nB7zVeajZhmmHCEKFt8cgQ84OJN7P~N%U!Lxokl<7O9T8CJ}UnYM9Qa z0@Yc^Z&#^S7~XIALcW+Q z;NViJqs)Frt=mxOUNId;LU~%i2e>Zjo%XWR`%bBR9rS(Nbp$6wNC~%6?lh;wu#Q@GXSRUI~ zSylCHsvpb854IZG+L;f_4ktdvLkqM|6y0XwTdw&9S-Q?hH57+glQ&|eKhVF}-!(2e zu7Bm7#OvVzhAaS4LX#cB9r-Jxp`V_B|Gghx1yGs-4jkN*u)ne;MaX&)0eMyYtdXj% z%#$c*LHH}TrVR)g^RIr|bg_}=>yc;v7~fp8IA*0q&)%$RZdd_bZ!0-~So2Ojmr2MA z_X*ZSJe{O50|--j>m?lj3^wxi_6V)77*&c3LA!v7MDx({*rIxmG4_UxuugTdywEP^9d!v9Op<)#cX9LFCSN zBip($KF}wi^|$oZFGxCxSUyY95bIrLV+pGz{o6uhVQjGw-QRx4gG*47?7=H}kFr85 z@Tl=e3Loy1nHzzcFK*k>b#|r9vTH1zlQbi)kMPlabJ5jt? zQDWwSOXoiL=tP$V{^TMR2K3(dfVoh{vUa^}-==%;%|`6ZGW0t{Y@jA2nM}d|BTyNw zB+DEh!l;(A9i4BDY0rX$K)2Z;CDy1 z&E_c#;?^x59;wFuvp~xt*}f}!l%$#ChmAylLV(u`x8RH^VV63 zn{3?p)hl*d6d9lvHylyQEm z=Om48nxhWAHbDF|<_*dUf->ZUpM$z_1W&%{&3{;U7Y`}##cR9+W~9p<1E|k%Z08L7I z*2oKXM<1){Vf5Q9T6cNXMF)X;dom31J58Shu_KyOf6z9+hsk%s~yB zP@FvrZXj#ihDJxQ1tTeAcD#jVJSg+P)=ju;E0Wfe%f`7}%|3p2HpWQKCuK6)NcgVQ z)z9VZr-C&)J;kKJ(6tGTm#z`l@mnIeDk*PHuDpUQgMeshX|JAZ9oIK8SZczv%+u;% z$j4FHXkhHoA*{XFlW!aQ#wRC6p8bnz7x!+f!;{LO1L=}lToB}u6OoA6jZax6NL{n~ zZGqsRD|i_fU@@Y759Np3?@7+UOJG4c8-V^0XaFoyV;E5zf(*CMcEC<4i~d&sSdV|f zTZ6mTDpzERb+NL*!pefar(6=d7o%@i)HSO_&}uX|2E z{WT++MVQB)<;gKzANMbP(o`~MCG~mk&S25?u(Qi!M)a_R>Lmvu=Mkg`{mw z1Vm4319J|=C^kW~#~VY! zLJFg1Y6j^?v}rYNh$oZgD+5fj$71+mx`p;1=3L@S48tA<&$988GCB9S7SPkn3&cKw z{-0f#E2BS?^IBk*XdVddbK=yO0S`X#3V2l1C*Y;rbI!KR>9^e1M|X0Ucd>0wz+fN^ z`UednB#_Y9ZO~rM8sBE3ll>mcldoKexa@6yV^#-2KDNh^)Y9XBNJG(gA_b+{LE;{~;2yp~9CW=M!jR$so;dDtt;h4r`>X@# z(Q)%OJ|1Q|4$Wnu%Sbr{RO)zN+oek-l6i^{>FSX8O~&D?O3Vz>flvYrNoNyKS6;)@ zS1*zemOg1*U-x~aUDyGE_{NSsr7Jg8dZ8$sKNh4n`lPixUjKG^_*QQh8=>C?AVlF} z8XX4^>iO+0{?>>*TvFxibK!1?=}}F)J}MA%K@WMFi%6|8p1xlmh=@5%DOa`?T)^uj>HM>BI3Yrxj^L|R%Hn3qdLf6P5k}JIcMgc9ew7~&Dy)Ct z9sQj(aAZ>Ewfb_^yO2M#V}sX-1>>lXN<{;DU^6V%)yB;X{lCcvO8ahVd(PaKJ-*9z&4ZOFozQ&OUem+W*ikjv) zMs%?Qd%}Q&TY|w2HvONb_!(7C_x$qe+rM~N#GQ6!upO4gv`;C&3&wi};WsI&1$;}w z3lU@}xYDG^=hElBB7P!7VIgh>Gop7W#J&}WUU!UCneK3JLre|R-nB4t(fkR^nyVJL zGmMtzFx;ML)1(-!3=rMaJs{_qA4tj!sZyN?05M_$dWu*piwUHsWlaBhY_5Znc-)<; zKv3W2nMnW-Y4j;hggHw~=?;RxoX%FUC~3I@H#n%`;i7R4NL^4C#=Q6T5)aeBuWof% zl?D07aGTvzA{C$G;2$p)q@1#H1575HiyU@r#BQEYDqv~%fbu+NWZ$tE`BG|E51TcM z>=LKB?q7qZW6>;UWsmsb1k`$Ut2&HLbz~ix?S6`TH~?foN<@x>-uF2Oq~#v=N`4jJ ziu(9WMg0eDW$zc%t%2+D$M2So3PqeC#+C+V^~gi2Bj@!hwEU`%qYZ>A->fy*R%{I1 z_VRE8zXOhs1{yuFr3GvOh9ms1weg4N;fY2Z&E!6{o8+^a;Q*Y z9DnK<1r2cIJTvRC>C@5@8`{C1>z+TS+jx2Xxq43nu7;XfcU4%rF?J3?&3K2o7|tvwB;g2U)LnDvZy zm+m#c`#8op)In`h#$M5GG)(V4!nIQ&Oi)-(M(Q9vx}N{PAs;)*W~!pPqYa66BlBiM zk~#cltFNR1FGo3g$&R|W%r-pHoklx0;l#GAWgud?Y;e_#@7SVzf|v0cO#HJ<=^OvP zUw(C)^AwV>HINe#1UIQ1UD zTzXWkbH7bU80#cmjMVy+1C3LUjEHs8d=$5#htmOR%xAminvdh%|2^i!#2x8O2@;H< zVHO(3^{XOWiUEX!`5Eipt zI*fMv3ea5Y1jdY-wj!Z$A<`(F4=lkQbfv#nH6H-6vrL?WM+1ap?EVX|J-Gp)hlxSP ziIMVnkUTGaw4%{ZUvI&az^$YRSj(=p-frZbHWx|teRw*G$TDd1&iCT6x!dM^T3H*P zzWhC~GPWzu7eCYG4@FA+ICtmUp(N;b+RdzVM1nDRxfq%FOvK9>ad`BJ2U0=f#V3b4 zEpN!oQ)EWGR%C$;jIIa7Z9z6_3ife-fI}}`+`4>tG^zT z`f6QS(-xk6&bf@LZS!3{S1MqxB{U@~;eq>U{w`$0+x>5V9ZQQG`h~3NL$Jh;oqI@n z)7Tse1P)e#P=*pG?}+8>{%eSMzN`6PZX3|ogYWW&Y~W)yll%y4>VAdh+mMcRk+P0) zde9PSr_wBeZT7~-3&jyh4%cnDDbH4xkX1V#Vwn{w@2EC=-3|GOZU5!EkB;5cA9P2C zS|$L<5}R~gug^;GT?M7 z6Ad*CJ5BDt~Ebrbu%RIus8qJgSO^Fx4&IX z;Mqnf3i7suS$HO^E4tt&6cN|Qr%Mlir`HF*Nduubh3OSHeF1le+oM{aN#Mu1+mDLQ z#{O!mO*}zAm9d_{Qs29Qbu#qWNZPMj7aImL^gp92p~%~wDk;wOPBSSsqr=ZX==1vq zG>shcd~)TarY~oV{N$xDS~WR_>weHx^Y{j3!bccMAI?$@`>istz}ZT#LSGw~MTzl1 zNL~P8y5r|)0~BDr3xSK)|3L@cr2h{0Z%uWx0O-23$gD${AtrM?pV(=rG*RZkQujr`d zOa_15DP|C%D}A2KlI8{V=fCF|xe=2P?``;p@!or`PM)Qsdz3m&GY+Eqw_l{@uZ1Sp z(%I_3*7jl_(OFEejiGQR3XYdqM)ssJ!zMSN;N@bjDPPY27=G1|ae0$nH-G`Xga5B# z{Xh7@S90Um_Mw(fG^};Fh8P{=G_DSRP2*n%z5w9|ZBVqBtCnBuGVGtGTS)3f&PYqX zMs&doUfSWW3yIqXok3!K$04R4(-IZ+_*mcWE}H?4;%m0sC%%tAP#{gdSEt2^?>7EB zSiLnlkBP995?hF{^gMZbON>WEts?&2EQ3jtzw;N&?xgzt249@ZTBP==6S?I}T)BAL z+o3Hw3z#2u7t|&qMzFzqwVn{sc`3=Y(R^A;O%JSP2c%HD?O~x;K5|^DI;k|+QTSv$ zkN!WNzB;POfPEW8#UKO(q`OPHJ0+FwhS5m(hN9Blt#pqZUDDlM0;9W|eGl*Ze!rcw zvp;v9>$&5)dveKfcMEgxTEgc;nkd+91pZ56|XfOL^( zKy+6!W)AN6)}PbCedA&X%jNP>l8eq0*`z{h`9H+~t07+GB_XT_ji6GVRy<#atB#4j z8iY$y_?{oz12IF0aUdav|1RufBld6~6HmgWh-3vZ67DaZxm36TEOCMhiDZ@^C1ILu zqcgvZr0)1&-7z!EF0DcTpA%{LN#(p)k3a1&tDcn9Ok^`BUUj7cPGFk>B_T;`3)^hn z*^|f=q67Y)U6+q;GuX=SPvw#HVT1(DML=eAy~ox_jW&Hz=qY^9 zL{wry0Zb6rGe4bDOJIOwfjTSpy|+d|ThKgjBWy@FkfSV0K{CUlTmkv;q(u1#+FxSn zlJU;h$DNr?Fwi0aq4rbYJ8tgK?@j!hd1P>2o8E;(f%ffF@eb(a_)j?%Nlc~QXFESN zCpDEe?`8VE^xWL`5z`Nh-ag^K98qjLK!xa`cEu zh%jHyXvvDGt&*qa39>Rv z$g}M^#8QGeWB_Nzihr!&#@nak+Nrl7NR@~mHKnWVeM#0|Pk5dRyjzGK5MCZHd0r=( zP>giSQzdl7g0;6`XVF|LDtNz~M7!Y>9`p-wJbfnbg{AEG|aWFj&)n*CSQ}}iYSQH^ysV(gvxi0U*SvhkS{k0v$l%fMxyS>^0G%1@)`lZymVLE9r3t-M*mW}~SS2-!5{Z%>*6 ztK9a-(+l-b)%7ZXOt#fkI$0Gi|ksSblt3F8)8?u}qnVA%PJ)G5-R2Nb4>9 zA=hsswP5=^lZ{l^_by=e5kIcem+0T|nVx~Im&N&CnPG;IHKc+L`=3*BE{U5BKPkUn zUOY1oSb1wacv8!!fYSq7FRjx*{ixXzI?dZ5fbG;p>Opcp9NwqZ!}%UwTeKW@Ts(f- z$?5UT)j)}zCNtFzMJOv6N1M(`anp%ez9EEAMF!n!HO(vHKVZmm>A1NnN>Q;pVU%!` z_^w##-+fRzWI+*ULcx2>(rb3nnx`IkYhkPyQk{38EF}raIr$w0cB6E<|C8^{OQ}I9 zL-#is=iiQ~pFQR#f*4@Q8M%EAo!$d0I^vceU3Z=jLxOjD>ETpQZTkO%gw*+JR0U=w z!q9R4{mUI|*HC*GW*^#kNUZXc$uO-%KQ_{WA-mh!3gLiGG~c;ad)T|$HSyH7q|8x6 zif}c}zFF%S2Nv9?k0!$2C0^K~c6&s$`X%HkukpA0jOawaQQ8{pp>WD|qqU78(ou!1 zR$v<&gD7a-gSO|Q-rT3laF$Y`VaQ>exayr{aL&BR_cIV-23NmoumY+5er(R)IO%~N z5L{>6?9ev!Rp>wg`|Q)ph-O!sx+74iX?;!VCOL(y7- zKn9r8LaDa`@4M%5JOuopE0VCS)9P-Vs#^LI=b28e74I<9kNaKUaOzq|wMy=i@9oaC z_mRpKbxHI74*MMOO9X5kr{Txu881XM31<=%`+2i)tfd+_r|Oohzu!a&JjQ(-wu^8} zDOP?FQzb9O=65j~u+{3l{p~^CU7&Jzq0LB^csO{Q*D zA$G3kfj1PovM0-orlz=XRL3Qw7y)n!t)5Uqz;14glN4|KAE(+uR@&nAz;+foSa$Fd zPCx<4&nXa&$^pH4<@)fJ!y!rZw+SZ^Yc#$HXX46@&k=dmJq4^MzOJ+~x-Dh(l=!WR zv-!2ll$W6#r3+uM$|wAG6}|Ni{7-5qiW94IA{ zs%^17zZ2NT`+N%DppK=1L2e)0a-a?}Xu3lT~$S&_D}sH0>N^ zg^D?pQ!%|Jf4-XR&ps{LOTu0`-->}4`A(S$F3jB{sfl)PPkxXb_NUc*X4GxtkJHk` z$^)dtfXpCvAuJx&bhI(9>_Ze@0z03E^AK14f0gBl> z!Odl{4>SnV@0^W^8c5n-yM(N=*)4_s&`UaG#0UK2TrG*!OL#fQGmwnWs_lJmL%&-e z0%#rU=fLbbg)+BWQ8^KI_dVPiN0Yd&0*l+bbR}XX;}PfJ11pYjj}uJCeL?oSq^?l- zyYWF41-d^X=Z2Y$^&Y7~GDUkg`D4aui(g;^|NOfq-?HzRTPRA=1#LeEHnW3?PEu>= z3t7MZR)m_|#a`uY{@hAkDO^|h=<%%cxV{e$tNCO~5;H?jQ?`u_8X69Ki@$F(a@XDs z+1Y$s`0?%&c9m#Zred(QZjoIt-yQPD&8J4h|9-CP8Xwn@vFryyM4CZ)5ZyY_$$ry* zH~MUX=b(vV%kytq5TYliG)Iv&a5?rqd<>>mZU;W08@D0kwXUSujQP6^A+$vvki0#; zBDMPPi8XA3%PSc4$WisLb2^#kM=MkzP%`EAO9s$E{SQy$ogRttfC6bM2lKq+sCls% z&v$_->*mNH=Oe*WCWu>0Zu!(WrpH#{0wy{L6>)oVmyxnQosONZvNg4JP~rP<9WTU$=mL0{K@Z+1$DJWt>C+T1_bQVId4P9pSUGY^QF%tJP{0%WfW(td48qU{9 z;p+t6`~_-aYvrSHo4uY5Ao|n57dZV!#C0RS;~zA;r}$c9WT9IoBRdy zzs>pC|CfL7F1tIUzU<=PHv>i#*JSn^P)+oev z2c0j_tn}X-0bE%bu8Gx(=DS$W{n4^Tq@pU$Qb*|2rlBOns`eMv5@?`&*`3l!`>~Q4 zJW72H*$CcS0E7}PM676{oHC95z+u00N#B$B1JkeirzPXs45C$~Nd_f-bTelaQa_`7 zLvyBEgpY*W?*3pUdQW|EfZL~&iY~B#t93sZ`MQlHJ-6>6#DufT7PpnWDH(UQ{Rb@( z^?YF3!-Ta|8XjJ@spYqBwKlN=xsVy_7}(T&Gp9?Pl54`u2&>emLG!%+aT*5saw+4t z#{ZQD@4rhItsmZv&94paW5HTB`tIA^c{;M^Xp=HG&1$3^X#ithe1mQJ0?>vGa>4~9 z7j8l?MD#Ou#Jbqh{Sa@&bFsox=fsh2}nZ5!@CX(J4zu?K@kzkH>cCsf+h zXN6civ`5k2G@V5r?Gx00!WeP&SwT;^f8`udRD93<>I+?!({yM-Q=}iqQ+WsH{}?Gz zCub}o6(?~@tBEnNv54~@+SzNL|pdKK~xMc-?l*7V+pCxVZq?BMSG^ zo9YT0ll4^9YLbujomaMKd*-zq&wEpF*n#|!!akjCA-dxm4%ghSLX~&$V<6$i#TNk% zCs)wOgl!WCs=g zXZH*7XC9*35-Ijip4iRx7yWRwiJ}y!hT?XdFPL7IjskNy*5O5w|3-oXO^qi; z*G4HG=yUDQ%Te9b7hA&WI#H49PJH5iIewT!z89?oE96-&PU;qLsos4t2YQegHO%s2 zooVlTkX2%k442az;^4lk6Nn3_%N8{T(!#3Q^|#Q`>=tnnjE)^RB2_&7vta#;-TCM7 z9*6fpG9V6}7zvp^sur@<3KXcs9*&!`__)xZ!j24PG{5a)&t!@}+|1UE^Oe>)crW&| z^{l7uj|oIic9E;x9BEup9mdJZphOi3PjTM=4qnRvzWVV~2&tHsgL?Iuo>r5INpGGQKk!r32J$KyLNYSku!_2!EN$txSGfMad1 zS*<`JpfUFy(3tz|Gc9n&I>p|Hv zU}F8oy31|CjDk?vBjVJ#5+u-0Wj-ZF)T$E^Vw>Xmm%dEqXz&r&de)v&U`ZaBP|8`4 z+s&Y5gj`%nOkI>2|59e!f7Pe8gP#8yNJ}+mHKUgkQ`{t6O2@SZ{HAJ$A#VZ)x8&>u z#9Y?s@o);rX`S};SRZJ}_GT~*Jr8E}$f%ay7|3ubNIZ6urF<0FUALrYd@pC_xi)Rx z}8aneTzkxCv(3EJm_{5pQWG6WwDN-Q-q$+dpY?r`?Z)Ft2A^ zeeRMt2GiZWF;fPAGHFTVpgj(S9uPc)N@Bu3aSpGm;u`?-E7cb{!dpcZpbic1t3KDS zsW_BglvP5Uf1ns%3?W%IU-`K`O9RwKWgepd0>=%H6iK?Bo{uwo zOggv{6KPyk7qL%XIaWm$%g}cUwVammo6q&p*AX>c$(Qr&rgNs>SM5xti&;P&K}AB} z(1?CiKa`xo%*gA*v*>osZy@uMl#0*FP%$@86e3mQke~e<#~!RL3L7L}QgyBwNE=z2 z7o^P!Ej;+x&RsjS)|c6B){!Cubu!{{6Fl98IQ%J<_K1_^sn0}OsrC?M*dr3(lfMS# zQQod7GoJ=C5j||kZIKgDW7{^b0#bg-7Jt9y{umm)nRGL+Wx(L}Eb7gZNRsBmsf4Bq zRGh&)!PbOe@G@=5ny=d$SAuf!`9g0@yf}B#TEmXhfOTc@AZ`!058B`22ti`x)CfOa zAKjgbKD~4llL_&1g4UFm$s%LdtYb!)jnYU+QOF*m7n`)vNqjU~bi6inDM`a03PDLZ zwJxQ-c_r@u$T8vEAhD;$N>Qw8v&9l_iNU*H#8DRvRbT!j)Buju^xbTolTrPurN~^oTi|Qh)6inhrPY5Jaop$1Ofk$_ZE-wZvy99$rc9W@ zH(IDt2(h=UpG1wF2=yKUHNA==Tht-SDyYk^k(YCML*h3RuS)l{`4R)Em#5$*8#(3V)aaqMM zf$mK1XJjIwy?3h88U{#UMDX?}O2WV>Hs?P4rP4MX?G+P;na!J)v(6#E1tEF+-U>yR z>b{5(6-{KtmZ2hy8GZNA#5~1#U7b4_(qhVuQTLQ7gpesmoXU-`yg=HS!!3rmoJV(v z#Pq{aTG%cxlo-<*`EDKi_8F9-fttf3#SCsT=)7B87AJr#_a6`PX3oaUfb9%@M1f>A z$=o9yiat!aW0#H>BJ{b-I%9%Zh3qn{qd1}_!r$b;+J3>dndM_2bf({cPJu!;C1TT~ z>%t2h5>Xzq7keF0`}m0Hd_4VtghXt0E`7nRvu9vC!yGfG82b^OY4H1(182?{akz4_ zOZfxaHv3u#Y>1DCWpxZ=N!Q^$P|GA|@qJ)Mdi!^VZc^0{!$6cTt54ovJPnCXssOWy zHC((@|G8s|>7=a(Nka0D;Y+G4Z9PPP`2b-0!m??|L?E_DJPewDY*fKEjZQ|6<2rwO zu2&3bJmh4$rCfP_t})KX+4kEI%*)}daG^%7jCHFf%mHG?nInT3u!yWpvnF+N>`Ng_ zc+FfskE)^*%b6A*2eXe$qm{J?sp%mmcqx3!vPQ6Rp`)&KWdLof1>$KKMAk}^J)8{~@jLOL1 zX3OV@OyyVnbyzTY?TI0M-13fd2K^ig&*Y-Qs5X+7s8wFc&eKL z_9)^Vk>OIx-+lO*kC*a|P*$_Sb?L#J3k@y#bR_t*C(`l*AT4AL*ki^{GTh@%{Lohm zA=u)ev+|n1siAgSL`0Zt{d@^M%E~S=fbWI)*c9Knb?09?*)sSTcqaSWd7q&oVYLx_PCUe5aDn(cyHqj%}lR>-tCYL(zmFYVGr`FB^SE)+M+Wn67Q z2sPsi-&`@UL(vx>M5MsnVt7k6)fJMX%gZ;_J>C(OrW0t=`zhfEDR^Dv6DvF<3m}UW zHVmiYpL&z0B%-(qn+&+JXJeUb}uFIO&MZ2_IPs7M$^B1qnY-aw$l4sm2NE~ zFm}CW>jT`;OI2&ENc(=IcTdkD7R$S+qbY%*1HT~! zB*iBKm`mPS2#dvy_CC)RbY#fp?hW}}<<>8g@1VZzy-ZEU9ErpKETq4-{%s&vBuPYR zEklBS>Vm|QiN(yOQ}L?#D$R^ugObG=3*gu0hGZ^5`)pxnn7ta+SUNXJ{~l z{OtI)JWDW$M#;qG8xVIeqi8h*B=N#DU+J9LaGOFrb6hLuNIKDKn)@Gv!sWbZ#&i(` zSV)_lrMv~{mc$L{B<9cu z>HPJR5+gYxF3HfX9-WIg_;n?@ZQ{~vUoY?(z0G=iWR|(sM6QbXtL>%-8f9vn?ng~$ zA?eX9-m;Fsy{tAGu!awv&PqcrwDnX{R&Zx>FoGGI!^_8~kfhfeHyg$h{?@pRJc*@= zh)5Ka*VNOfm~>cW03< z_hIutg8iMZ?@OD_*7o&;oQ8yt^c~}UTrlDzV{C$aTTi~9Z^K9}goHXkB| z|E5H}HS)C|2?}C;iIqVQagj>Cx6E7#2wPJY-$147$Zu_4Yj%0t=r?$3I-nxG?|PB# zhTMkoq{z=IX!!G!s6Q`l+NC{18?GgO{=p(OZAL)+S9QLV62GShAIwl##aRenO=oFD zn)Gh>hxt20XZws=9&e_V_y&zF#udTZ_hq|y#efQD+5_u)JGZF6)FkdUK<5^1Qxjb| zT%#{me{wZhp>k-HV*EOQw5yITzML(eQvgU9pmDXK9%hl)y6C*jRq^Q!xN+ybNY*FevuSMFj0UdK zI8RvUAzh*K{NR@30m-;IO&j5A|3|DCj+r~(?W2&2PkN;87jqxshkyn29_}K{RSx8_ z=V1D)RA@gS*J`=HY74o(K5@BLfF1zli>5T=^t_jD&O&`k$_iGr4`A3S+zb97`OR)3 zRSwK(nqLgPdF9Xa73ukJw2Uv2ADC2lvb+qj67HJFhZJRc&n5`oTgQ!F%9VXOYhRrm z$0~36Yg8rTIgewWYHFiD(=|0`LYbeES$Q2^Ub#1aU2~KV6!$2duVO`squ!-T)N_=r zJ`}qdI{Qth*B+_}2s6&*ak;(XoqGEuYP4uDU^HHe#LRVyw3I?VD*PIf@`{T|faze;9yQr&f&=y%HzuAeEqP*9wE>dBJ(KmVZ( zqecrfVf_Gix{gsX>OkjL$xxkziI85x8+5R2TAN%dl$5}cLbQfwx`kdG& zhvpOIB1|)V=*1=N5&l;i*}+HcjcDKVflr!UxmF$V(5=kJ;ePtEFV=lUz8`|qSuYC% zTkz1d8G%Bk*k;qif{Fvy*zQ``E(Vv6wI=#FR>Foa=j?tkdCahl_8u-4|FA;Y(5bj> zZM&0FNrAOZYlKE`@ze`UpEMW)-of6ucVX<*px#goD}SkPl;4cLqItAK$c}EMVgEbaHXC)RHY08n61Eg4e6A z%;WIVj$@u=Oc#_)-?hyaiSEspW*EkbE=>O@D;+OqceD?kWJZK?YTJk<^_F0dQ;I+9 zq9~1kW3b+evn<0iX`UzRo0o}(3!Kz_j3q43me=b#EylDe;A(gb?A`P85%+~@%YL_l zOe6dRG>JVDz2gkU@F4(CI=>GC0W?n)6!SmXj1b+OTaG=QVjnVLcMyYdp8p8^v$U6*PJZtBssrofe zM&5ttIJ{SwBpP+wRgp9Ow(ObMZ?Yo!4G(=Err5;4Df3}w z_<%yqg`?43%Ir?e?p_M*zU?N;=znkv3Mj}UBS9ye>Q0h)Bhn5_*@~Cu#l#frGmOHcX@bsFEv`)dWai82U zRk*$X!F-|@{T0uEQe)znpUpKCX*PFw_Ps+E({ly!hhXk>f+-*2T*P@?j{`CBn7QCT zG)+5~f&C9%>t$vsv;hrM0XFWJ028cLBl^-&$8tq}#kmGh7{hlA;GB)wz{Z4@BQ<-) z)6!M@0W`ZMnwNpt3h9a`_X?B_elIvbSXP)i%~vDzZUwNcOGX~_acdTdPxG=sO(dQf{P@bzBr;YA=dC#s(zazWc-tE>wbU``L2sbl{3eyor7_=ADQFD!(3d&@e;P?j z_Dq$#6D`>~bBu)sqejH?B2X6Gf~!a6|hhcdR zgv;s%HJA(M+6@ms!AMBtoX=~n$6NzBln^{{ymgvFMT&Y#f^uvetcdWtQO7JHYj{Y9 zo_&`)dcH-`xaWH@b5kO~vOaj~Z(nTcr=v6(+$YO0a$LtPzE7{xknUjRQ{cy38ky(J z=+;kdcc#x&#;AODJ9w#i?*eoSwny6|6wDzA8fnjX{hso0wSznIT6FFw{~<5pe8$^j z4lh_;gi#KlDWBW>2W&-rhQNmdBu=A$poqyU$5Yek-FBJrVr0+`DXf3sXVsOx*KMY; zxi#V>5!!K%{#R5(wR{OEZ;wuRG1Ur+&C3Me)#+t+r8J}^;+pS?7ZOT?o+8-ebA*!l zv@*>YX<&dgmxv;TWkOFBqy&`S_k~#;X-IE4GPeL(>lfpL@lGRXaB5jbzSV3=AN^E( z)5}1HNX9YQ&L&mcVYpW1%k2!1`k6eI;xi;y6ackTi&)y?V5R7#d36ts(6cjqVPtcU z3`axv_#xxSDyrZ2x?8*8`S?BNh%H*aZcLlV&p&4LQ>SEO%PVdBxzsz}+|+9t_OBJR zXzfLQXu24KG>9VsTQW}Q5FLbA=;takBv;UBiwi#`aQAtiAqURyG~)7P?$Kq7R3Lj= z-t?+r+(vi)C8w<#?ZLw0t1}TQbhQB>?Xtq4#cum-+Qs5IYxJ`qKFAK!X;A{2)=-{L!@L?TKtuAyBIdgdI%nb`Gt zrX#+w(PUBb^TsXvA!V`9&AEqWQwB}l0J(ay_W=47o6qn@=i%L(LtEq^j3*Vwb5eGW zfYL!13sfF58}w!hj5oUzT+J)oFhF|b^e`gdgq ziPo|=LhkGTqJl^%vi?M-eWV%7NH)RB-vLg)74Z2%i(e`=eH?~F9Opsx2)zk8TfW*J zMFlCN67&2lSioYhqQul2`UtD}LM8xnS_bb<1;U!q)RNwD8ou8@<*s93Sik#g3t61> z-5Dlr)zB7{GvMJaa!YUjSXS*elK!=?@|~)mbhn)3@=kth)f%@J(X7Z_Z%Cx?){6m^ zU!7b`>vl-wz@_b1V!xUm+S%-)et!dp8kU{Kxb(Al`?(SRN+)aBHSZ@<66x(RE;5l* z3xe~>%8F%PSLHvq=6CN(_luts4>8jrG`~$dTyPHeV3e zbuQ#B=xBKY?z(~qRps5-%_OY1g5F4DCe7fYcbpy<x*$?uVP$Gb%BmPhMxh@KAvnL$C3>KxL#)CLekEzE$Op&gg~ekMHh;%!YNCge_(B~ z#bQy-DmywSP(8I{lYe{fYa+(}c8aElnvJ@rrr_nOMo*RZI$>teJQGDqC;q`+jr0C1 zAcET=F03q64a}WMIW>oAEo8XevjDAMmfe}x5MH@aF$iSRV6Wjw>rh&CjHgQSpnUfO zcD=lYCXb!Rb0p)}@3a~g)Jd?wM) z9432>>774GfILkGpt8OZL8Q1+*`p1M^0J&Qaq6ufxZ8|mJsLmh$ErLz4$WcxvKtdT z6|fd&ek7ZrvhV8UauqPA)X;+FHL+B*L7|#6CJ)MOwJ-ez&w;vgp>5nJ%BEMvS>DJ+ zSNdJ=vI>J)0rAVAz)Ihg$Gl?xreQ3du40K3nsykae*>o;iAV=z&zUF9({U+!X#qU2nrh9?x{@!2Cu1~h82;aUaI?!Hw=w=#;?)&iOAGg~F*S9-g&c2r( zZt{0ksJ3iWxZ(;Am=#aG{^V!C1+@mUSJql^HG|Zy(p~(RuMI9z-gIr2_cvE+fE(FY zzs1|~iPj;eXhsynlY~fperco?85Q&`KeVN7h)%#BV-sS?^VV7N}!==3!)h%}d2^Ek#W{d=8*YI3xQ z68ZrUkDUL9#mvSeoLh{cwtV$DvL5F{?(VGNQYd;+0%N>0RHk9EDNc-!5Ga1Hm3PCm z2Ippakxcm9`WDBsKk;yXE|0kTE3QBlRlAvU17+nQ$u2UGzZVS0^=jmrb52n(^d#QZ z%DjUm)h4Uo%x;~c3;?4u$i0!JU0Pi%H7)N+b~+YXu6cp<0rn@*LABEDklSR>-(Nfg zO4OEx#t%3sl+47Ol6-UX?8~EM@>{%L@k_BoGcn}XBJja9UmSc znPUKz5mTAnZ^3t34AA>q2oo^Y(*8tlf(276+S`d^wDi7Bf(YWSC)X53uO+vHj7>&7d@QiSVlDz z_Q0%=7GGdFzR<<4xRN> zHHXkiF|#h03imBR*_LgP4OsJQx_&}E#}*>6y^~nv(x}$=T-$t<1rlAN zK~xcJtGCY$nnb3GuX7Avmxqm?69WWCWUbk$!_+?1p2;-T|N zq~V&tX>*u#t0j@iAj|9D80w1(hC*f~yOEZZMng?_I6Vm16y>8o3`7G-)(Y{FeypP9 zX+UqIf0*Z8K;{B9Hp<0;3^z7b%(oEQk_)eRmZ5ESR~vXW>x{}|CO)6N2K=WJSesbk zZ05zMoNdve{Cy6t%nxn3E;RZPtzdrk_|I3T-5-JG+u0iAL5Y#9Kh}FqyxEv!|Q$ zq&B5`Oa5_NCFB;q!IBj`NOQI^K6H72LiJ2h({{O7{u^qklR#lvIf%y>2FB6>AA zpUU__KW;4Px$sTr&;zK0ewTyNV^sF~qsud922=xkHJO-`exu__BGfy!=t(vy`5^9r{SO#~+Cy{D39l z5Cn!deFvEDbb^y%|I_vV1TCTcp|nf%QtmCzKqXJ+*SGz$Gaz&^-prm5AKq`h(OL>+ zjkq66%iIbKcF-ZEkC5(hi(OAJh&bKs8_ktdJ*RD2R za3GP>tgGCw6iZce^H(;rEp%CvB@c&GJG3pC*uypd7MTro0Ne*@Ub`&BdP4cZ+$OM} z#IjC@4#)7$P9T`&Wo_j~$!p{KS85&-=U>X;rm|om@cO^Qb%2GFXH8IBna|heQz>K% zIVr{-^6;Ak29bKLO+Wr9b_ir*(&{_)T(U6EQBlQPWUFxL0MUpoa}45qxmjrV?bteI zqT2j0S$yQfk#lDB-uz&e(fMrQ^k3@c@HL6OrOxSM_vSn=V?F3q9vBG`*b;ZIV0Mg|mxxU#rLF3dqqS|~YrN~EVYHzjXXPR(}u zf8aU)*wjrVF2(t?t54Ok){rE)4~)iOa)924`i$MSBwCRaxve8CW^QQWSC3#&Ne( zW2U21_QzLU7?VDyESkbJ(a?HRs=NR&@s^3g@Xvn+C(st0U()imTY6-HVb#98PS0GG zW2sl_PXm3rDH+ml;Eog?g!!klX$b9IZSt6zNdI$wd#MK%G9(~-NDg!d-7Z8NyuItb zx%tB?R5g6FGiR3-Ieb~u^+CDjZzd(Cz!?SnW~XL)S8nJSucs=Qbmm$q_4{0QsGcwv zI+H@jzIq_WPL1U)&5Z2|(TwdylP*)&E*k`qX$K@@ubsvp3@7(NpT<>2Smy?#w0~&` z{9Wk7T{7_yJw8|=BKYv4P1U3Y{VV=~J81mvY`;0K^_fnm=tf?YTp~vId)U z6WJ_vbo(F`e69?Uq?3wf%FD|>2|;1$t@67QH3HmMN^=vwR;F9FG|M|_=?ELwFh}!t zgE(fjI}eFzOCiUdfut=py0)rHTg@9Rt3@(w<etK<`>Bad#f026uc$K5tW&>Rgnq4ZAfrh1yDW}B zA4MbW{gIJ|!$cn;rPyCAUWm>3L@-}dDhmQ#!8w8@LYpPf`0%&dc0i2^i5^SP@}N(f zG`aRm&2xuj2XCU?bS)=`2;B9Yz|4lFTpdi+v9hynH`!@(MUid^aaJMl*}v=Kp#YHe z+N(NyY&x0OyKcvm*}r#^lmb80;uLd*1C|iva3K1S%&hrfo8`M}9Jfg?r$f4(Xvgp6 zbHsy{PM$zkeY~cTGJM6ytMI1S%ZyUs1W@_~WxGIPomL_ZuM+K@==q^}cj9x|u*?`v zk4ydEzffRbywL^%eB3GN_+=`!cO7mCd1{OkX_*k=Sqw^_MdpmF%A(A?sf?LJ1DJ zdtdGBFbkn?DX*rGKpT{emh`gLtzmhGc?S(#Tzl4>57n0gD+oFr2P#w~dgKb4*6_OJ z(3ExL6uXIHKQz3Yuo0|jE1DP`(FF#4rWmB(mJR4%n_1jy)HxLwgfkVDm9RA-p4U+7 z1t^o1yWe=^XJ526)#G!US6^Vp{6U{R!sbb97Kr7BS5r}C106|)l-|m=?WcLqQy;z+ zJj4M@{GaTC}3d#%+#7Gdy=qAH8h-=wB3{D!?5_V%R5vY<(2JE~ zYv62iIRNKsKNmSA^CIW6vZ8aHox^e_&4UdY$cM`UDXv zpfV0T)K%BH(IK|2ov7i%YuL+jVy@?5GdBg z7@3w>at_=Wvgsy6h@x^4(G9LP$bQ)vUPLn_iFFmG9&!vPOM`tC0KfROwHpJ6)FkxF1DJXJx=fw#0VEJhb!9+y(cSirZA*$VzMo%YA^xs!V%W7Qylf5~CDVSclWV zw_))Nm}0})NXxKgkNF82oZfyrM(v?!oFcS}k5`Xjg1Thw4ybJVuS)vyiS zI>h#D77ai=v>*KH2-Vd^`adH?eXj7#`}|e{A3Q$O_P3d$R{7J@Vd9~>pYH#ZG-gBU z{q}w?p+-Yr9eW3>N+r&WvrU9AIF`|jw<1&ZHJ;O4j0^j(LiM!Sgz_+)9)EKev1hYg z&ol@(POV&+`zk%>y5s~UwNAdJ2WAY^pKq-AHH=tno|&*XHQYf2{k(?<&wWP_jyFaH zSK+JS<81krG&cF;I+A8bmP7M)qj$TakX2Noovyot`1`%qnf}ATRuxz8=C7wim%3%O zR_pxf7~lO<*?hllCU2W0K*8$zyk}l}4mP}$4$_^RqGzk?GvLjRogVy&| z-qs+m*Xffjn{#x`&ydBEvdJFdBc(FtM1c!kS2(+mvj!KkkF*v{mny`pj4PD~;}1IR zWo37A+dlWRQqg6%tb#n%&|~82*~5>ok}R@01@R(Vb4usukZkAs7$c@GAg-*Tw@D?U z4fGes{LH&dp&>A46f`ckM1@G|yn~p0{^NX=*uuq*V;oR9dzLnM8O0b=Ilg zvmEPoxotXbPcFqj+xRvj-FflB(A^>84KyUXwxuMtwp~ZxYpz$dHPQ%?j7heVEMD83 z%I6`CeDM=8Zg`E%8V2<}-@eom@jjpHg>Ja6&q#)LlYkZ&{OsB^y5=}i< zrFSk3#9F3mXJE~VOVOi~tApYz(t47ck|8~%T{kzwhL+ILBGnO5HN_P>$ACr>tP$`* zZ2R99kjFy_=;A_X;3_kiLVMbR&+wL4^2wwL%X-`?(4 z!Dr=;jl2CKkH~J2TaQ|*Dmrj`)M}ZG2G$PN^M$J4oAH2see1VQax(*ARr};p+M|b^ zUi4lVKer(FPJI>QbFVOEaiTS91W$D1YTb@K?T?a)_K>5DuU2jl!?K<8+si+W$bPOs zWmgRL78L42-R><#RDq+6$v@l|;)Yg6SP*Y_@{(Ap{@HRe-Dpk7TcoNn5PdGbgg&0( zgUjc;f-Ljb*bCrvIFq9^K=1PEth@9CM#8qkGH8^GiMTr>5sWOqR?1h zR*HBe^1&~7C-ZRLthm%4fslVAjEJ_Ck;fB?%Oy}(#dtCnXw+keO!#i!r)eZ$D^s_{ zsu8$Yl|^o3?elY_xm~-v`wJ;KGr#+}I_&^$I2{pWIZ(Fh`{@h&h$cJ@KbapoNZ(wc z(-1@fACHsgyi{a-_6IxXo? zto}6KMJ{EkB$Y}x{=&Bx${%@pIT1ql9_s=4S2L8R!l$_lGgMi=m(wN3CXO%F(e^lI52tT-u`!vb(U@w$8wWof5(;3F92 z+ARm$RiomZe}9E0v3}mxEca@=dkY}`=|P?wj-rV5;^@|^G7?g~&ae6=f-FQvom*Oq zhQ&w7jaW{8I^Q7!mlw5m>-MH59T2*koDO8b`ez2{v|&qvWf>ojGw)F!dG2icmGA#R zl*QYENKv9$b`^h|sou%WiNew?%pTMeM?xYZ(;8DAcmKLl&4>qlG;;r1;*Lhs6CvTR zbSt_@dI+(Dn7k^7d%Bl9e%6IhQ93*q3tkd^Kx9Pz#e7qZAdM$^QDe3(3~TcB5=9?S z#(Ft8J^*gcd-rk2UCQnp$GFg;>Kv?R@$qY!ce>(PXB zJ~+I7$h9IXvAq+hf%xH{fx@NTE{3xKSPm|8$(nJ!K3MoQ4RSQQc-(!9y0t9`-1DJ3 z{kKw>UJv0pBItoS^0fGTVs=4t3|4k=d;)v{%jxb3aH43a|8(Do5ti^zM4p{%w9(mG z1^2D+p{CTLK70clctMo0zf5T)IH8+#yz)t;@3T14yG>&R9b!>ek(nyq`%K^j6A}K{ zwnBNVRU;~R-75Y187Z!gKl#5e<)!v38ml#bz}=Sr2KxIG?a5vs;|$=xIEW|<==`^G zUD40ZMF0t{AiEUBmaxNmMa+*%)noJ)S?u?`?LkW>9@#+m75-z|=P8xBlhv5l7H>QJ zrw(W%Rwo~^kmvhPzqWOEE>l&#M&Yqv+kRl?|Gb!79KC`BW%mj^@f^u|Y;U>d*4-3s zVSgL?zRi|5VJ^@kDK}AsuL=N*m6EdM;qT*3Z-9T`x3)7Eg4v)#6a&HN5&vtjlpW$c zFw#*;G;hPr`@37{yT68{T1P?+Bv@=KE$7)6L7r4^zWXb&Ok71`JR_f&4;Q+wgI+l)IN0px=bmU2$%+s9V^5T8`FAeSbFAM^t%m+=Oa_BKtQT zt?o^HKOoRh>V3GZVS6Lrhv%W?)mW}P2V1@miKELFVYuybA(Mg14eu-GDFqYQ&46Nw ziV{S*xk*Aka>JjRcU+%Yh-9-?X{b2}iP4XHEFw?jJTXYjKJ`2Z_oze=7j(9U=%}vl zzTiFMtb`NnIA-`3q0NJ&cmAc_2U=0(hW#5-hm=S^j+qY-b1h*OwoS&Ph%0Nayd%wI zki>Z}y_&^qOQRaRJfiG%-c>kb@0%{7I}$U9kEgzKJ_%=8rkHZfrt^X&HaZOMdUUkN z$P4|*VHmIObMrL{=N9T)*LK$xFugHziTl;_U2;St+zVxRuNXQ+u14FFf36^`YCpnL z$&+t7k4>;)EURy|xNG*;m!mtx0bpeL=T3?gNb{9^jFir0_O@$oUs#nka(@Rqiq~U4 z;m*keNpe8YRV>|3s)*k#mko!mhuZKE<$nvZWL*c|4&LZQYjs@5@?|Us<121wwm6*7 zzxt)s>?t*Nf1obY%qy*ZA2WsdqSREC)d;ao~jgpJ3yS`L>#mS)7E%$`AhdKA;Sq;65(oyT#RmfagTd4{xf(#HNe zh98jij@9Cw2B(*yl*_)#$TNopr49Rve<R210XL4ieT z&G$R*oJC4zmu#uFbbq-s4`rA0=f2F@X%zB7$1Tu#skc7#>G=1POy8Id)s}LoH?d8I zpOMlmswMNCacc7CC)on0nEZMXJ}UW7;`_B@_^0vF+fd)~-hz2S_~%{$O$`W>jU!Mt z8)}-TE)yFu8~ezeD`)TE3ip{VSQOSsCvAyeEa46rP|LmRgw80jc}U>weJ*Q_ohPU# ziHgHb@>LR@{-#O193VUuv(07n$|9KD)U`cuc)KOBpJ=pj|5N?`0zsoxnIP zBz|x8jQs#JCwucMa|x0-`!$sz#9Z{fPw4}+Jln5QihI)&R*8j?SeA}g80-^EIw z_?~6o_TK#aFhR=^#9+o~uS2&0WnBAq0itz3n#UXVPrrs&A7d0t$ooJHKa}lg`0CkL zd)0}5TY7KwjCGJgCmlhPr-0v6P#6S?Eg{peEe0+YwL&`*%6YQvJT6U}_)KwZv zcXXY&&tI1RN?)8y!h3{N2nPjTjEQ+48U7AkI&WCV%#5L&Y1l##(fa(Qc~NN3D1YAG z+_j-CWm##w_|UkdVLZht!2MUQE;h_uBJ_U1FF5VkRh|xee>gS1J22Cd8t*oF zUBX+Q3O|BT^0vxro85EnZ%!5^v0NjVnLTw?{j*8I>w`USbeXin(=YOAY_VrO4{;pHOaG zYU-25>1_L`jdQ3ww_}8h^Pad?t8(2vqMUw|#VP*Cn+sR;qh|%5=j#A3uhd~br?G0z z5gCG24nf7}@Hi0^%fGF(_}WbM3Uznd=vpI7;Gg^z)7`#3VXORtj&-<}OOS(2Kl*a` zHEp6RqUa3Si4`~7aXmfDS%YSXt;;1>{w@(|`f2cX4BsoJh4S#J-FpF7qtMQNbev}V zsxh=u)2w=TWl7kR$NwH*TDZcM(chORY0q}JrlE>;nNLae9x{B={Bv>8Dnhkw!0gs? zA?f`#ln|oP<2j+keqtni8+V)i06VkXXWy!fTSn0YtWNVMqu=5_H6KnHe?qruuAO?W zE!70n`|wVz+?$9Jael$f?mZpKV>=r`-c8VjN-)4m}lY|f;#+wFst=UkY&!TJ_I|nA5@1!}}!Ds2bta~d}cyAGq>1Qm<8Oa+f@59T{*<*%sO{;#*O5XrBIpALgx@$y zVFSqlsV<6imL{M+$92(+W)=K~=Cz^K8A(Ua_x-CKxwvDyMM$)RozV#tJ(o~DMp}`> z3+oEyzqTeE@Ac^O<6{~#Wdv*M91Ke}PyC!C5AfGqcgpLWlS~$VBk5~GX3Ojj{Yy7^ z%+$|Vuk3{O9LpxMZUdLiXL%rIgm3P3Jc-WWROR2aGXFEdH7)pGn`%mfSebyv%jn;w z15t*;1o>9GaO+{O4Q{0|Yb993lDYTHIH!IG%Hrq$*qLOlLWvjyd&m5nsfcZ*aXlPo;kDT~RRPy30mE5Zp2s zg`tn;;l?=={E=JB5hc>JXsvy2Dh08_y=>BfwwA!RR-LJ18E`Zs6TbfjrHgmx`4T$t z@~mr84=Fw9eC0-^p#r~3OXuUMw*}kc5th9cV)wE{zGoP^8T_MYiu137s_rM>x7Uwq zoAU|1mk6El|9E%{-e@A!Y|#L%-OFeu5TMb1)g9$ECz8I^*$lTdO)$pH_yE;OVsI@& z-U&Njb9^s*(c#ULX~6og9B%ZMfB$kp9%GHRO_PJqf@qYVvCx#TxXjQLc-!=<%QadS zqHvBuv9CNIiif!peXzcx&oVZ;?Fre=~T9kEC-gTiomKE-5 zCoaQ1`1z)LDxahGo)cYOVD!fD@dWA%glkbb8Tczbjzg}zIRuuT$0LM9hG^Yr0axFr zZVJ}EbNd{z3S#&4WJ5ycbGROUagB{iU%`)}!k3>Jkro9#h@F4|AdqhZz6qrL*|uQg z)k3ph{xyyZ%G`Up_Up^I)BemO{;kJ54#yjT>z}A8d(|81-lf(P!|BU6V1f~&(N|CP zR2|Qnrh1*q9jLx3qfaMeF#L??3e~$K^CRR4&^N~2*xgF-5`ycU2XKfch%){#6Cw5H z=}YsD1Phg~triVp?`?uUH@h*+$9X8vU!UnKB%Xuk0C%;|_|exN(n%k-uT=~_Vsd>& zr`7t5%?^YVBJ`JeHYfaEEf<;oxzk#x-t!o0yUR$T=e>#65rlZvoQ`Mm7O3-R9zRe` z>D_7Twh`~}sduj6dnL$6{M9(WNt)Tpu;Dou-yyDiIA1QyU|!VLhc#ord#XQShU}@} zM?Bg+3mZKF65+*5eVy+-#Nx(*G6}iPjPE}AjHEeNL3gUVDNg^|T`}#$S$%56+F7u2 zvd#yTjeJ&r^NSBFmk{b82z^6S{3BI6ty$`?rWz*b*!*`8_ow&*u#X?nlkwhULK#@j zDv0avc8R16q}|frH8)q~c^Mvd^uS8}U0ivhQeEkn#YR+^Urqy7&a2LS8>*r_({i%7 z98hbIyMm9A;H2I%0=;~6?pw>Bq{iEJGsOTC*3X^SVmXBL zi}UIVa?i9n*!GlvUV|s&%SI7V)R>c1dEqhTYQoH@Dx_fjb`&qC9B8 zsn#!D%G^(Q15FrQ!`AMuj5IbE>^#pPHvZx*`1Mp`8`Lhv+o>hy#Qk>KomD55j@X%* z;lc<35H`&0vor7rUO4AVOB$A`uj9v+x`bU&WwmDAWADgyHyhBp%Pe12(RC>rMeIK zXRk7ifIn$$ZYJ?io#*FFj&m1k)2P9z@vO-E`N?XmAI#oHo>25%kc2!SnTb!EO1l|@ zFz=4#qFU~O#4dD-I9q<(2SHI}V^g=__6etxG+Ttv_q+X8o60iuB!#)SThoViB2IEP z3dUYGY^T@s-XrD&v2^cBH_hlazWrFUKwbekchnUYR9;_BI$dLtho7yycuf{x&DA5u zZKvFdeEqk*M7w7~{yTFqwPPV*$oPO*Lp$a>jn)1Uy?!aerlMb_Xp==@-=* z8=Fjn?v{&Wx3tLSI8-dXveCDde%(X{xOOOwHLHgN>WhonTea)gXS`@!>Kq^4l;8}Q z)^!(d?K5O5Uh$LiN}&fCMqSi(CND4U1(ha!OS>c=GC-F_O?<=_gQg%2e1wR$cPbDA zyO=Ith|A|qQcJH%R7TEsWI9|oDb{{;qUq##LRWDDp>Q&8RBTQ99&D$-V?3~<^2nt`-WAe zp|!E{#=Is?OI%v=f&WV?V(z$H(zRlLYz86Qi$`7S?Xc$~8nIh61}vAlgrc>$&uco? zy681!O*GHnTz9M68lBH@`1!r7Kh4q0fgh{`xmoIQ>cWu$>u!nw|N8dF1;n2Lj3jK@koWlc~KJ5GMC`uf2Ikyk1kBEe)ToZGxBuZR)8se0LoRhB)xpejzXx^*dV8skiC#2Fw;Yg04*nn6& z_0tRf-M3CAoD8{v__L7LN8YZ^11NqnC}AFC87Db&chwSPA+~K)whQF8F)ARC%Vwa| z?muiP#Jd>3mN%td5sDTNr#0!Kjr0&SrR0_y#!_H;M2c8X5OD8Au*lYKk((S43bg>5k!SsS7MVIQ` znf)9_^wQ?ngtldV?I!+|Yeorr#87Xpjo*@!)(R9$F9>%Ve#KP~6xf_R{}-yXhBf9( z{64q8!YS!XZ^j<}I23v$ybSI>fdpDO42Nbjf?cQk*L&QR4`%?YyYSIK9w@iQlM0?Q zQ*qvta%wO7Y0^O~?K2+q$URV>B{t6tsm|aeREJ+v)s>;XOg!<4@>v5E$XNUsaZ)&@ zo%RUk=eu$3_2pAetkR{vyBoe<^4>O0AKUnQtxLP`m(c>&H`3Jm=etA#0Su6gw0!Y5 zr>y?2V)fUEM+6iBe9)W*J7Bn}X|Y_9e*ol*WfauD`V- z36ALV&%HKk7rz$&nEqUaQ(n+FlTCvTO1QiK-+PKE`1ddOE>Q4)KNbn*J}^DF#_cpz z{){C}!%VyK6<~k+swp8FgS+wH-(yRKW-P7>_x-y0Z216Rq&|nA#-tdRPV;8?H|xiJMP&u)9+wUnsSO;0{M@Z`0mDZa z_#Oq5tQ5gg5bbJD@iQ0y6TJ>xb9r~a0EUxx(|T+H)erw==_IdB{z43>^q0dsXx+am z>^pS1od@*39CSXk36?y)n?_O8cHg9%zHDt5izkLROK$kS(${m*7NUFuqI=yenjKb@ zl2+@Tfcm=}o!hbuy}!5POrHguy5dVwmN6Qw@I8r$_EP;nj9(u6z@DNy&GIda1-Pt=@OsY zbX0t9)%DLmGSiEgG0wgX!K$@#o@qog2*%%>`f$bB3!V*9J!j!g<(DY4a7E)C zo>8GAYwtZTOk_gO(N~7P4-Cbu9Nm>asWK;QFLpB&;lD4N?H;XEm;ID~<8Pfoh~OSd!#sri3 ztn4)=0`sM$cAK*CaNW+ZIhr8Xzd!5bdoGlKMmzVV~WZM#@J#vr73OoOB8dMyb zcs=$v_zyv#oitaw&R|ZDS~{OqPd=D4&Hf=_zQ&!;(0Rq?cQGp zkFQ=Vj$+R#d_nAB9~K_d=R|SBGOT>(YGBL@$#OJaRkbR1MJuk-D7XTX!LHYW3D+j} zV|&^?!USp9nG8n?AI|J__PG63fzS*FcD)EGWx+cs3}ogy6*)!qH$ewo#>@;;qq}Uo z`sC;`*AKt1+EAN4Ha){JmEShH6X8x;weY!ZuC|vaN!=Ej0!94`qMccmoLCv6Tr8K) zRGMt4Xa%)(Ti#l!ej=} zEtk*vmH!$))c51hQ8{wtTZtXePL{h!&8_2R0qyewu@$SRvaG!dfHkZ{hT)z$jm`pZH(eXsUaAx{jc&J97V%pw9iYYo#|&$lkRsO}`WTC=^DWd8l81#qpW(g+Ga=^n%>w1lKY^+Jfsv6CK8B|Q4`nNx`(~h@mC#MsSHYEhXh>S(ive3! ztIKIB<8)Ck~}f6fmj=vsmPd$9MCm*1{^lB+0&&TFbn`H?Y8sO_NV zVpMBKW>#$yvrESqM6fVBev>tX*B8+b+jGTV1y$bhF>G}?3z)U|hf>{MXx^vL)1J1c zGewJZPQ7(+ZLPEON=p0yAS6&ST`>N2m|>$#fPNbCEjHZ;5gw*!(!XnstRfOAm`*$Z zMnPU+41hKs20$wf63}{Xv!Zb`K|$Euv;lVN@mw9b&m9f>*8ru94Y!m_$t;$L9NAA4 z8t(`Rvhv?kOdNgTt7ZML?Td{|{cD!afRjBrTe2 zLM1QpV5Y)BMURyXy;TS$Jk$ccYg*>JZA?gJ#y?@-`~x`pntEQIYAlw~_`DlOG6w`` z^sumBXHFd2KLDI^Ca8s|ety&LOR_v7d17A24bS3*x)iKz138x-AGgu0xusYYE z)}iws@vLddH!Oc9eu6DYQc81ZAdnQ%8xv7s$+qxA^!{Tf07rbQdIHf!RG#59HKwHj zI>^x%(t+L?NR6AI&vT=!^K~VuX-=v~*#*Geo}-aeZ2q#91Y#jTBGwa(4x<58@(40z zBTkowTUS06z7Kr3_~fIE@kwRwWNc$)2SmS@%ySA-*|%A#7LxXFdw(hJ_6`@I1)jH_ za_33BB8rt+rkA*d9VKTY49s~=PlC#?rq04d9lVUaJBo*$7c?jc+$UG=C7$8rnM;h! zgch5NzSyu|wtL4r!(m?X zA{YF|>v-a3(P6*LF3a-qMPylw%_o&t7~KUSL_>I4JDR&Wrv!k>`H7kWqZXqnFAsJ7 z>i9-K!oxR>qv);uGzah-(QiGf??v9Sh;PcDGw^}ywnf-zILd374?6}3w7sY>?xv9) zjtmg6l$}%_4G(hwbcH#Sb)d+yxR8A^TU%p!JH@lC+wj$4|0acX;OImS@;r^kh*`M}x6j_N`1E{8Ovc z%`xSe+pOmob72e>^yj3#o#JoPjQ-t@Il?>BQDMl094E&}1`toNvqoU{Y}+JHhePri zhC@H!z)`%dQeAgeRUiNcOJ&n4RV8Z-{vAdQ{iHhWHC$8=NSpn%^1BcvxaYam(H3LK z#tF1%7!%|}FcP53;S+Xd{HEA#Q>NnX>@s#=Dh1>f9_OsyQ_MpqmpPZ$OcH;!V~m-K zXXjPsYk;O18G|2pI=2G*BOw#|4lSEDE6yiJzZCb+aq+A9fC^|0a>p^^hT&zL*(5Z= z?*MJIhS+sK2O$S-8bub<#Jb_TutpI z>JOSH2fliMWM-}`^gA8hKY0ZvN@1f6ES@3TE&iSBGe+JyWrh?JQwzCvwXWL*!1LY| z36{JDtW^M^M=08zohs!9&FI3h;D_BO6RF^@k7-=wU%8xZpid`^|G?#P2;h>ItHmC# zUE8!>bTBSjy;BhGZ{oY!(_s@aTiif~3iMNceO}Q`otj;<#i{2^P}yj4HmlyjTUI7V z0*^27ixz|_z5y7j0<{)kfsIu2;}aZ9>mDVGlTbl0?(=hO0yG9*RfOAjiGRCp9_Pp@ zJ^HuEWvRaOBzz+EJViDQ1rPMF)_WU=o**;RO8=Aw=pF_#cI=T}w{#eM^7VGH3gq=p zL#OzZ>DX&&KDOan_QPKF7MYBl>E)8?_>3MQnJ<|b2d?Ln^#H8pr0D+(Ry!H2M@pPC zYVNwQX8Zt~x_Z1ftKikYXRG{B1p<^xMma}t-_KcL#8?_wFl|961I2te` zq_2c5S*rO_317t$69SZfk_3XNKi$nM=JcjiEo-wbQqN1_jvH?GiuYwRFd9!x}nw(i%hCLr=x z}J*qDs$$0iUor-}_AC4nqY z0Nq9bf}B-bIGKaWOYdaJq>Kmru1v8gT;|v|3dQ@RW){y9*^pOk;?9Pm_-DQ5Z)UfukH@t?Pa=4R;agy!5flUek~(Qm{Z<+BJV|GMh_WK2|Af&;MCn zQE^eJbZ0c96K}L~xnKW$hIDiX=w1VER+?q)u6G1iG@Z-8U zIm9skHSebYG}l)$Ski*jWSdxDW9o5zRl8@j03nh*sqg17<7JzC{{`Ir3C@y+LhLI5 z%SqJ=*30+E$X~~aIc_>H+37l9h`>yXi{`QxKsC53@=dq%jl>*Q96#477@WOaooU)* z;XU19?P4pRmEZsQmp`w#PwI(*nAg)cKYtIPEGHKKm}c(VRRIT3r>!e=;M^p{W^OC9 zmm!{lC(`P@4R4nQ8Z8x35*4p}EqO68p~08^fb2K(CqbcSCdL{5y*>x%wHkHHi9Z6E zwep9*y66I3nt+XN9QjJ%t>ZE@i4gHnvsH1B9E47cEgEeUrBDTc1x0}A8e-m9)IL*N0!Af26LxHc8{ z=c2;AMEPzc+|Nl}EbNN3ZRL#JKzUEgSE`%! zs;IU&E6rm`WrpNj4J0w5mR;F6Dh$`sSD*STF|MczH`c3ZU?;;@=)b!4B~#<3q%qEP z6nx?N%5M1c2SeNqO_>)~9~-+0XG7c(09*4DFWv%vY`ADcbzgQi&1<_6Ky~Azl7O5- z=Tu9+v+kNrw8L{j3lexrX!EUX*1+zNKXy_4mqC4a_~}U+Yq2@Dr7J22d8%9XRf>P+ z3X(!CvOa#SJIqV%2)uV0_{a^vRXr7U^I~agkKy2DA5h2eM7iS`r#Jj1hJ0{M)5l>) z-B&M>bcF+gZQaVd4{EeG>^1%j6|#YRcwvRhVeeH(wY2&eMSVBK2z6-Hqg7H>eiOYT zZ+Ww!%Fe#X5RJOJ5~LjFq}m(~h7Yi_BJVOW4+aiwT4t8Uuq1@%6FIUzuCDdPBby<^ zT{epj`Y>r^_FWM)H*=96K$ARuZTdNYrdkj#M&fkf^y_+^Kc%P2hjDbt^lPTI087cD zwE*2SSAci$!VZ8`q{egJM59Qza?f$Khv6`RE6=3Et97>JR)TQP3C+4dCbK2P%y4LUxS=J2x z@e~iJ0GsdSlN~lqJ(=j0OdEC*<|~9BZ+(e>vH2T_n;!q%{>{XFm_aS3cnl#~Q(uv* z)Hk91sy-RGEvIV#FG#UukcQiB&rP-;mU$bmfD~|avzOb~%wi!geY5QD9mN;C2q8Mz zNB_b=y1gF-8rllN8VitUlBcJ}A4&y#ECURMs|m|>iOK4k7S(PK4W$?Q&D*F>p6s;g z)TsBR12rU2AXoYmsWFm(*r;9J#sWvrZE?QMG#l*aiuKE79gOg-uWLC*er|Ex`@ z4i6xAFH!cm#W#ICvkWc$VPZK0u4Ao!tg7-7KOeWmL6xG*RJ`jlV?##;LIfhI=EVS6 z#6*JSsgV%r9Haqqr`yhcE`NKr%Fl2nMwC{e06C9(>wL2u2>rqS-CUQ zKq&bS(tOhAzSP`;acCth6}+y@KBK*@G23`qAuhYDSHfItsZ=McC$6#8xA;YYTg&2`rU|rIAsde@SwMi zI{9r&sI!PKewjS2r{Yev1Us-W7&gq<-|hd?D&Up(3?CfePhhKl2(LFgxqR)paBj zA&`~V$$mIRa8G$;B}%IMtU$mjB1yoT`&SLZbhG?$h&Jz2FICkuXpQxCF>m|nTPOdF zK{?Jl)}T?^1KGHQ8+4=1sD)*vH%gxW5k3w_RFqi*6Udf4x1~r~&G)0H6&V?5;a_Cj z5^q^LY17#%TiH=P*{20Lzq!{7jp*{`vtVAAg5sZ@8n&WT9wwQ)kRM~@M75nNgy|<4 zgk{j2SBOd2lBbak3N+8)z~vsW^J<{)RsFPR_#SAcgFGL-DMqr|H<#pdF7!LZ;bO^E zvp|;lo?pF%YAy2ai{rrsueaFulq8{^oi!d3g%iy9{rwn3-PHFSmRa)((ESCvh4Zfr zyfvKOksBUZ=lWofeQCG6;LAaFd`mzfwEFO03%5sO4jnX1R*q16^BEMWSya!UqL&m%gq_<*mIBUAsfmYZdMs_LBk|wq*NMI zf;hAIi<-4nCrysGik#W>$V!xD3%~)6uE3%<^67SmlOKJ{^G@XfOsXFs13F*{%&xv? z^MVNhUq`T2+b*J=%|D>g@4pf|h7d*R>o+tC2Fqef}y#r zfPL+IpkX?$K3l9v4fxBg`02EVK0#uH#5bDsHn%pcM$obIlCv3<&7dd$&@7$m%o@@56Ke73aG+Julx4;zN*=2c&!pbX+HBQ=z~_ANJgg)c5kz zrf5tzyhQkVT=Zy)r#WyDfr8yJezl1LJ;l{K^_~^4smLx!c26oTf^3OH4!gw?F{cMR z-+MG=CpgYghvr?YQ`WPR-??t!&D$og$B+1h>tmmrL7Bwk#0^_L(~z>#wPrRYk^7Em zzR!>FCvmqlAotM zdiHe6j#JLlqcSHNyEWaM*8UdNN!E3i-pJ7G zr&b`WWdHPoV>(_@KN3b9j)0ZXli$hNn6R)g^(95fjFtCXqdLg3eGR*M((;<^S7nCTbdyvpOLMkFucClwz%bT;ID4BW-|`A9zq-Ep|7fIn^v z zmB7R!r?cAY@X=-FdIcYNxDa(1wYj4Llng{ysb+fy_Ck*=r)`zF$S91|J z7FpsO3haLpT)W-8$LEN(Yqo5&ZJ;Uo_<8@789FE|Y(jrak@zIS225lAK_Kwmv?6{c zqd<_yZ%@<8RdL5!^n1YSSQddL;RmcuR7u* zsac@PO7`JBNxj;bx)|v^!<3dx@8yFeWgwdzydi)H-&lasFxg10tz$bbZCGc%z2`hM zzk|+kzrm1@07Lp|ejMcOU0c&(KR+3H)dYG>RGuujN|vI&0kCEr4>N2euG0t{ z<8l5ybAl2k2;Cbs^~&EuJ!bbG8n!<;N%@fJZR@J#5g;mEsuiuZukr0&*WM3E} zx6>a?od;UX!epU(S(RV=j6#o>ILb6!uO%!wk&;Agw_QuI4202|H@L1&(Ihf2JOLYQ z8kP6-zPrOTv;IXrg3^YXK)YY54Ehk7i=iF(g~bTL7#Z{`l=J*#R9K}RiWK8KBt>>` z_GU6@89`U6jOFRMgno(hahXH6MhdlSCq|GLf9}i6o4TiZi)tto%~&34>`JHNOSE_e z+$;F!fRXCisIVg!B7}g0MQaNfs=Phnf*G&k^SirKj_(6AWlpmg&K)pa$u~fGnVfa6 zw=O$KQUPfuklMAhz_`Q=fLmE!ZyE{A%`O>&fVuj5mz(`u?hb9S)te&!D{%<@?UIR1 z@8ll8(PzB1pF&9$#!_TWU49<&F1XxtYloZ)Ebr$Bhgzg5YRk?Hf0g{srIi+*X(_Bp zJ`}Yjc7meYejM*9)Y%Tuq~ZP1$}u(PC#>bY0fkYiWW$+{>s<~vs%qqRxiG(tk}B<2 zN(f3H38Dor`bS686;2Psw|T*GXUvfEY}3=#psfUNqbZ{QqTjm<%rYE(1eP&eydr^q2lSv8U3YCQ0hPOE;SDEL~FTjs+(+ zD)j=kV_-v4U<{;dOubi`%$#iQ2emftwEIOEhx(h|#K|NW%-NxO1UYi|) zw$hv)) z_U<2BbOArBLQ`yCzeD(YH-$nR2PaZAJk;eC+02dkF1MQ$=lXHRQtwFO*)GP9Azgo# z?0DM%=hxr~c~9y*=M|K_%lJn1y?(yF_=!WLU%pwwJcBb~5qT4wb|{bIt*d-7cn^#z z4onJx*fIwsqk0q)Zt%qKG!EDkZVF*vhtzm1s(Tz%Nx`g-18kL2?raPF$v0?{H{=91 z6a_rVyf5kwHpFCE6VD)zYH*-Tqv>x^XdR39HZ0HPI+(rTy~AZnN4B&iQ%GS|PhG+d zB@yMAOmBxR`tp?@`vY~U6;QowM4zQm>cC9KAKFU-heD*j-Yo&R+2C-P<&NE}mCc!1 zOOuIEs=uhRo}BR z>#a52c00lNrM>I@gz`j&tvA8J=UqXd)A`kZs?jk}Uod8bngZG1{lQ04Y5ESGfq!#p z1+k#L8D4w$0@>{qc*#y_LNq+KK}+HPId%-u*o{tX8>s6hP4;ysuIc>(8tG0@*l9CT zoOCK^Tfyl;E=QySM?^aX>;v@WQl=pkj7}@`k8?H}TY@e}fRyyBB{Xn`D&CM}JYEZt z&7Q_q^D=K8$MM=F7B+W1l!yD8(#?BgjhgXGn?GXsHi0I3k-clk$T^%-vy9Q@4ff!t z`fo4bxU$PDvaV$Yw$^>eZi>Edk?~wb^%xJcJadqP@FCnX&ju_2k}Es2yNuF&bDQ|H zv-3Z*5UFB0+A8m|kVEb=g@a{MxSX&1F7kY4#ABVb;x}Z)=q3Q6NwEX`RG>yjPIP^Y z&i21k4Wh<2mByg%Juz#?-Y0^s|UH@r%u89&uJ7G{TfDu`f{-)`bp7>~xTHv3bD7t4F1 z-4lfTP#HM!i=eZVBM%ti!wtug6OzQaD!xpaWU(QbV73@+0jEgnQKo@RLlNS^4e-lX2$!xJ~r&)!uTsM`tNf-=j?Jh zK=%g_a2f4g@k`vo*s-qA39{PdWFYg950HfvBgS4+qo~sx2b^ub*%#*ph6+RmP`I*8 z6RKKfSGUDR8QAa@vRwi0Cu5qg%UwQ@9~`bJMH<|xLN5$WVT;K+Nxfju|?y2$_+-h2cF8t3Vi1VH)Qxlm#BO$K;33u3nr zw7gaHh;BOiqrf`?V^=wCOm{Bgkx5czO^i;qjV^%=AxJ!JJr7hqjRyhCWM0+4ig}|ELJl*zIwCJQn~( zN5{vZxV?{hL+!!W240kb5KEr4T5!;a$;D~M4q?%tqV=hUvy`9J6I97Nf(|QRQ;|{e z?*^C_5##rGW*5m2qcyT>yHt1F-BoF#v0ITdh##mET^kC~_vD9e9qL6Cf~n2L&O<0J zDJXdU*9ig6XuFrT(AiuNxuv)Jcy$UC9pb2Qu#vZ5Zb;uaIPJ!47%|a>H0Y^F4zN*_ zL}YqruV$>~hg!OKodA2;@Ekyc@9VJ7xf4j%(-xSy}j-}?~@{g~-(eDG`%r*cfb@4%S8mh5!|gLbQb zXJ)G-)|rE3UM+-pd?Gdl^2@wZkC=)MTNh?T)xQ`dcS_w~Mx9Nbfefmon%=WS%$tff z|6YsZQHGPm4TlPVT;Ya$oo>EXG7*i&%&wjJWR)l)NpU}r3Lv+N`8YDrVKDeCX;}1l z;n;(2?gW4g8o@Qg>C;7@3dkrCtpQ^Kga3xm^bIr* zM>u?fm-_SbF-$+Jr9a2kb?OO{Dg}NA@2nsH`D}j^Ft2(5*2>=t9#E7q=Cr!nWWMUZ z&)t*!Yj;IjR)5mg;y5Xq?D;%wa1lOF)=aYL0Pd_km;E`PNNnHMbvjuOmSb>j1@w5M zIkoj1nbQ)#1YMt*U@l?n_sbdkEoXm8>E)QWvQ~5CVCcAy4?}sJO*McywWlf07mNz3-k48=%WjHV zx9h)r`dc3%*`r(7Dq+p*e}QhDU|5>z%^6>m^4A;kp*2S0rql*mx5TGGuHTR0DKs;Q z>Ch?Xy-LT|shsZTzlfBV_m3faQRd8k>k;7Y1n6T6{#LygD|WX=FSj{)@ZL$$l`ZOB zeyWR#!SH9Es-h>D@p^2o1i*YF)MTY03tU$U8vt=I5C{HO#db9TiZl-y}`b&G6PV+$*Gq^w3p(G*GyEZ`d`8pkgErD>->+j=H z`-mM3beRJhuB)$km{x`l{i)u^rFrLMY^pZdjhmdsYoI(HVaFk2!Z4)@OjUA*-{0ID z4WUvDT|RLp756B_FBNPd=a>D#fh3|EqHxlAR0Ir4A!|6v1DE}#*9)EFj%ib8qdR|t zpF;$uNpnD+kDe@8H2gIvj`TIj#%)jLH+k^;d719dO)J+8TP}Du`AON0qobY@+z6^5+GAb9vjGF zu^z$L1Dw{=okqBRXNMm3@C{h1CuiFFjc+o|fMtfhdN~6L3RrlDE@0Cl(~T9-l{{AV zQ!C}W<$3dvhBEUBktVl-_--eI05*TFvEO_Z{8TvgmWl>4oO?R|v(^jpT6+Ai6g!&( zq0xXidS;d$6!ihk-j6}NwP`5`hRs#-Ar@hT-hh(@=LlyoI*@G6z@HG8*Pz4ULYnf? zVQ_jIbtm=VH{q_F?3^b^-lGF@iBiUY%H}m+Bwrb%6^Y{M`;u@NB literal 0 HcmV?d00001 diff --git a/docs/dev/getting_started/getting_started.rst b/docs/dev/getting_started/getting_started.rst new file mode 100644 index 00000000..87cfe463 --- /dev/null +++ b/docs/dev/getting_started/getting_started.rst @@ -0,0 +1,111 @@ +Getting Started +=============== + +Client +------ + +Angular: Our web framework +^^^^^^^^^^^^^^^^^^^^^^^^^^ + +**Angular is a web framework that empowers developers to build fast, reliable applications.** +Maintained by a dedicated team at Google, Angular provides a broad suite of tools, APIs, and libraries to simplify and streamline your development workflow. Angular gives you a solid platform on which to build fast, reliable applications that scale with both the size of your team and the size of your codebase. + +.. figure:: ./angular_wordmark_gradient.png + :width: 200px + :alt: Angular Logo + +Get started with Angular, learn the fundamentals and explore advanced topics on the documentation website: + +- `Getting Started `_: Interactive tutorial of the basics +- `Essentials `_: Basics to read +- `Angular Overview `_: Read through what interests you +- `Signals `_: **We build signal-based!** +- `Zoneless `_: We are zoneless! (requires signals) +- `Standalone components `_: **Always standalone, avoid NgModule completely!** +- `Animations `_ +- `API `_ + +.. attention:: + **We avoid decorators and use signal-based alternatives:** + + - `input `_ instead of `@Input `_! (`Angular blog on input `_) + - `output `_ instead of `@Output `_! (`Angular blog on output `_) + - `model `_ two way data binding combining a ``input``, ``output`` pair + - `viewChild `_ and `viewChildren `_ instead of `@ViewChild `_ and `@ViewChildren `_ + - `contentChild `_ and `contentChildren `_ instead of `@ContentChild `_ and `@ContentChildren `_ + +.. important:: + We try to avoid `RxJS `_, for the most part, in favor or Angular Query and Signals! + + +Angular Query: Powerful asynchronous state management +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +**Angular Query**, also known as TanStack Query, is a first-class API for managing server state in Angular applications. It simplifies the challenges of fetching, caching, synchronizing, and updating server state. Learn more about its features and how it can improve the development workflow by reading through the `Angular Query Overview `_. + +.. figure:: ./angular_query.png + :width: 250px + :alt: Angular Query + +**We are using this extensively in the client to query and mutate async state, you should be very comfortable with it.** + +.. uml:: angular_query.puml + :caption: Sketch of query state machine in Angular Query (non-exhaustive) + + +TailwindCSS: Our Styling Framework +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +**TailwindCSS is a utility-first CSS framework that speeds up UI development with utility classes.** It integrates seamlessly with Angular, making it easy to maintain consistency across your codebase. + +.. figure:: ./tailwindcss.svg + :width: 250px + :alt: Tailwind Logo + +**Quick Reference:** `TailwindCSS Cheat Sheet `_ + +Core Concepts +""""""""""""" + +- `Utility-First Fundamentals `_: Building complex components from a constrained set of primitive utilities. +- `Hover, Focus, and Other States `_: Using utilities to style elements on hover, focus, and more. +- `Responsive Design `_: Using responsive utility variants to build adaptive user interfaces. +- `Dark Mode `_: Using Tailwind CSS to style your site in dark mode. +- `Reusing Styles `_: Managing duplication and creating reusable abstractions. +- `Adding Custom Styles `_: Best practices for adding your own custom styles to Tailwind. +- `Functions & Directives `_: A reference for the custom functions and directives Tailwind exposes to your CSS. + +Best Practices +"""""""""""""" + +1. **Ensure IDE Autocomplete:** Set up IDE autocomplete for instant access to utility classes. **Very important!** +2. **Use Predefined Utilities:** Stick to Tailwind's utility classes for consistency. **Avoid CSS!** +3. **Responsive and State Variants:** Leverage responsive design and state variants. +4. **Avoid Premature Abstraction:** Don't use ``@apply`` just to clean up your HTML. **It is fine to repeat yourself!** +5. **Design Tokens:** Utilize design tokens for consistent theming and easy maintenance of your design system. Define and use them in your Tailwind configuration for colors, spacing, typography, etc. + + +OpenAPI: Type-Safe API Interaction +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +**We use a generated OpenAPI client** to ensure type-safe interactions with our server. This client simplifies communication by generating TypeScript client services from our OpenAPI specification, reducing boilerplate code and ensuring consistency. + +.. figure:: ./openapi.png + :width: 200px + :alt: OpenAPI Logo + +Benefits +"""""""" + +- **Type Safety**: Automatically generated client ensures all API interactions are type-checked, reducing runtime errors. +- **Consistency**: Ensures all parts of the application interact with the API in a uniform manner. +- **Reduced Boilerplate**: Minimizes repetitive code, making development faster and cleaner. +- **Ease of Use**: Simplifies API consumption with well-defined methods and structures based on the OpenAPI spec. + +By leveraging OpenAPI, we enhance the reliability, maintainability, and efficiency of our client-server interactions. + +Resources +""""""""" +- `OpenAPI Specification `_ +- `OpenAPI Generator `_ +- `Swagger UI `_ \ No newline at end of file diff --git a/docs/dev/getting_started/openapi.png b/docs/dev/getting_started/openapi.png new file mode 100644 index 0000000000000000000000000000000000000000..b10116dfc71a4bd0eee9f35ff3b17175c786f439 GIT binary patch literal 60150 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 literal 0 HcmV?d00001 diff --git a/docs/dev/getting_started/tailwindcss.svg b/docs/dev/getting_started/tailwindcss.svg new file mode 100644 index 00000000..27b8a8e5 --- /dev/null +++ b/docs/dev/getting_started/tailwindcss.svg @@ -0,0 +1,15 @@ + + + + + \ No newline at end of file diff --git a/docs/index.rst b/docs/index.rst index 27d0231d..68e81eb3 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -36,9 +36,16 @@ Architecture Hephaestus Top Level Design (UML Component Diagram) +.. toctree:: + :caption: Contributor Guide + :includehidden: + :maxdepth: 3 + + dev/getting_started/getting_started .. toctree:: - :caption: Table of Content + :caption: System + :includehidden: :maxdepth: 3 - system/gamification/index \ No newline at end of file + system/gamification/index