From b50f437ea03a5582bb58fbe7ec9ba7a9c70087bf Mon Sep 17 00:00:00 2001 From: gcch Date: Mon, 3 Nov 2025 10:53:45 +0100 Subject: [PATCH] 2025-11-03 (bis) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - ajoute un .dockerignore. - met à jour les dépendances. - utilise bun comme gestionnaire de paquets npm. - utilise une configuration Vite en TypeScript. - ajoute les fichiers compilés JavaScript aux fichiers pris en charge par Git. --- .dockerignore | 11 + .gitignore | 4 - bun.lock | 163 +- composer.json | 3 +- composer.lock | 41 +- justfile | 32 +- package.json | 12 +- tsconfig.json | 2 +- vite.config.js => vite.config.ts | 14 +- .../haiku-atelier-2024/assets/css/main.css | 90 +- .../assets/css/main.css.map | 2 +- .../assets/css/pages/page-panier.css | 18 +- .../assets/css/pages/page-panier.css.map | 2 +- .../assets/js/.vite/manifest.json | 253 + .../assets/js/api.CM5TBNEA.js | 21 + .../assets/js/api.CM5TBNEA.js.map | 1 + .../js/belt_Option-91f3b350.CMbgtZ-W.js | 109 + .../js/belt_Option-91f3b350.CMbgtZ-W.js.map | 1 + .../assets/js/dist.CzYTlmnN.js | 405 ++ .../assets/js/dist.CzYTlmnN.js.map | 1 + .../assets/js/dom.emspS_OW.js | 3069 +++++++++++ .../assets/js/dom.emspS_OW.js.map | 1 + .../assets/js/exports.CurVqjr0.js | 2718 ++++++++++ .../assets/js/exports.CurVqjr0.js.map | 1 + .../haiku-atelier-2024/assets/js/gaffe.js | 4611 +++++++++++++++++ .../haiku-atelier-2024/assets/js/gaffe.js.map | 1 + .../assets/js/gardes.CYxPzOAc.js | 276 + .../assets/js/gardes.CYxPzOAc.js.map | 1 + .../assets/js/index-c1cc4c86.D2nZEikK.js | 273 + .../assets/js/index-c1cc4c86.D2nZEikK.js.map | 1 + .../assets/js/journalisation.CEgm28xa.js | 1845 +++++++ .../assets/js/journalisation.CEgm28xa.js.map | 1 + .../assets/js/journalisation.js | 3 + .../assets/js/messages.CqHLtCes.js | 253 + .../assets/js/messages.CqHLtCes.js.map | 1 + .../assets/js/nombres.E65h3XxA.js | 176 + .../assets/js/nombres.E65h3XxA.js.map | 1 + .../assets/js/reseau.BY4MrTI9.js | 353 ++ .../assets/js/reseau.BY4MrTI9.js.map | 1 + .../assets/js/scripts-bouton-panier.js | 32 + .../assets/js/scripts-bouton-panier.js.map | 1 + .../assets/js/scripts-bouton-retour-sommet.js | 87 + .../js/scripts-bouton-retour-sommet.js.map | 1 + .../assets/js/scripts-menu-categories.js | 23 + .../assets/js/scripts-menu-categories.js.map | 1 + .../assets/js/scripts-menu-mobile.js | 325 ++ .../assets/js/scripts-menu-mobile.js.map | 1 + .../assets/js/scripts-page-a-propos.js | 39 + .../assets/js/scripts-page-a-propos.js.map | 1 + .../assets/js/scripts-page-accueil.js | 97 + .../assets/js/scripts-page-accueil.js.map | 1 + .../assets/js/scripts-page-boutique.js | 369 ++ .../assets/js/scripts-page-boutique.js.map | 1 + .../assets/js/scripts-page-panier.js | 1204 +++++ .../assets/js/scripts-page-panier.js.map | 1 + .../assets/js/scripts-page-produit.js | 106 + .../assets/js/scripts-page-produit.js.map | 1 + .../assets/js/validation.CYJDC5vQ.js | 45 + .../assets/js/validation.CYJDC5vQ.js.map | 1 + .../haiku-atelier-2024/src/scripts/gaffe.ts | 2 +- 60 files changed, 16928 insertions(+), 182 deletions(-) create mode 100644 .dockerignore rename vite.config.js => vite.config.ts (88%) create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/.vite/manifest.json create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/gaffe.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/gaffe.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/journalisation.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-a-propos.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-a-propos.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-accueil.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-accueil.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-boutique.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-boutique.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-panier.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-panier.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-produit.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/scripts-page-produit.js.map create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/validation.CYJDC5vQ.js create mode 100644 web/app/themes/haiku-atelier-2024/assets/js/validation.CYJDC5vQ.js.map diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 00000000..e18265cc --- /dev/null +++ b/.dockerignore @@ -0,0 +1,11 @@ +* +!config +!db +!web +!.gitignore +!.npmrc +!.swcrc +!package.json +!tsconfig.json +!vite.config.ts +!wp-cli.yml diff --git a/.gitignore b/.gitignore index 51a5fcef..91d407e2 100755 --- a/.gitignore +++ b/.gitignore @@ -13,10 +13,6 @@ web/wp web/vendor web/.htaccess -# Compilation -web/app/themes/haiku-atelier-2024/assets/js -web/app/themes/haiku-atelier-2024/assets/js/.vite/manifest.json - # Logs *.log diff --git a/bun.lock b/bun.lock index a096af39..68cc559c 100644 --- a/bun.lock +++ b/bun.lock @@ -6,7 +6,7 @@ "dependencies": { "@logtape/logtape": "^1.1.2", "@mobily/ts-belt": "v4.0.0-rc.5", - "@sentry/browser": "^9.46.0", + "@sentry/browser": "^10.22.0", "a11y-dialog": "^8.1.4", "chalk": "^5.6.2", "lit-html": "^3.3.1", @@ -18,7 +18,7 @@ "valibot": "1.1.0", }, "devDependencies": { - "@biomejs/biome": "^2.3.2", + "@biomejs/biome": "^2.3.3", "@cspell/dict-fr-fr": "^2.3.2", "@eslint/js": "^9.39.0", "@playwright/test": "^1.56.1", @@ -37,7 +37,7 @@ "eslint-plugin-perfectionist": "^4.15.1", "fdir": "^6.5.0", "globals": "^16.5.0", - "knip": "^5.67.0", + "knip": "^5.67.1", "lightningcss-cli": "^1.30.2", "oxlint": "^1.25.0", "picomatch": "^4.0.3", @@ -54,7 +54,7 @@ "stylelint-plugin-logical-css": "^1.2.3", "typescript": "5.9.3", "typescript-eslint": "^8.46.2", - "vite": "^7.1.12", + "vite": "npm:rolldown-vite@latest", "vite-plugin-compression2": "^2.3.1", "vite-plugin-manifest-sri": "^0.2.0", "vite-plugin-node-polyfills": "^0.24.0", @@ -67,7 +67,6 @@ "trustedDependencies": [ "lightningcss-cli", "core-js", - "esbuild", "@biomejs/biome", "@swc/core", "@parcel/watcher", @@ -251,23 +250,23 @@ "@babel/types": ["@babel/types@7.28.5", "", { "dependencies": { "@babel/helper-string-parser": "^7.27.1", "@babel/helper-validator-identifier": "^7.28.5" } }, "sha512-qQ5m48eI/MFLQ5PxQj4PFaprjyCTLI37ElWMmNs0K8Lk3dVeOdNpB3ks8jc7yM5CDmVC73eMVk/trk3fgmrUpA=="], - "@biomejs/biome": ["@biomejs/biome@2.3.2", "", { "optionalDependencies": { "@biomejs/cli-darwin-arm64": "2.3.2", "@biomejs/cli-darwin-x64": "2.3.2", "@biomejs/cli-linux-arm64": "2.3.2", "@biomejs/cli-linux-arm64-musl": "2.3.2", "@biomejs/cli-linux-x64": "2.3.2", "@biomejs/cli-linux-x64-musl": "2.3.2", "@biomejs/cli-win32-arm64": "2.3.2", "@biomejs/cli-win32-x64": "2.3.2" }, "bin": { "biome": "bin/biome" } }, "sha512-8e9tzamuDycx7fdrcJ/F/GDZ8SYukc5ud6tDicjjFqURKYFSWMl0H0iXNXZEGmcmNUmABgGuHThPykcM41INgg=="], + "@biomejs/biome": ["@biomejs/biome@2.3.3", "http://localhost:4873/@biomejs/biome/-/biome-2.3.3.tgz", { "optionalDependencies": { "@biomejs/cli-darwin-arm64": "2.3.3", "@biomejs/cli-darwin-x64": "2.3.3", "@biomejs/cli-linux-arm64": "2.3.3", "@biomejs/cli-linux-arm64-musl": "2.3.3", "@biomejs/cli-linux-x64": "2.3.3", "@biomejs/cli-linux-x64-musl": "2.3.3", "@biomejs/cli-win32-arm64": "2.3.3", "@biomejs/cli-win32-x64": "2.3.3" }, "bin": { "biome": "bin/biome" } }, "sha512-zn/P1pRBCpDdhi+VNSMnpczOz9DnqzOA2c48K8xgxjDODvi5O8gs3a2H233rck/5HXpkFj6TmyoqVvxirZUnvg=="], - "@biomejs/cli-darwin-arm64": ["@biomejs/cli-darwin-arm64@2.3.2", "", { "os": "darwin", "cpu": "arm64" }, "sha512-4LECm4kc3If0JISai4c3KWQzukoUdpxy4fRzlrPcrdMSRFksR9ZoXK7JBcPuLBmd2SoT4/d7CQS33VnZpgBjew=="], + "@biomejs/cli-darwin-arm64": ["@biomejs/cli-darwin-arm64@2.3.3", "http://localhost:4873/@biomejs/cli-darwin-arm64/-/cli-darwin-arm64-2.3.3.tgz", { "os": "darwin", "cpu": "arm64" }, "sha512-5+JtW6RKmjqL9un0UtHV0ezOslAyYBzyl5ZhYiu7GHesX2x8NCDl6tXYrenv9m7e1RLbkO5E5Kh04kseMtz6lw=="], - "@biomejs/cli-darwin-x64": ["@biomejs/cli-darwin-x64@2.3.2", "", { "os": "darwin", "cpu": "x64" }, "sha512-jNMnfwHT4N3wi+ypRfMTjLGnDmKYGzxVr1EYAPBcauRcDnICFXN81wD6wxJcSUrLynoyyYCdfW6vJHS/IAoTDA=="], + "@biomejs/cli-darwin-x64": ["@biomejs/cli-darwin-x64@2.3.3", "http://localhost:4873/@biomejs/cli-darwin-x64/-/cli-darwin-x64-2.3.3.tgz", { "os": "darwin", "cpu": "x64" }, "sha512-UPmKRalkHicvIpeccuKqq+/gA2HYV8FUnAEDJnqYBlGlycKqe6xrovWqvWTE4TTNpIFf4UQyuaDzLkN6Kz6tbA=="], - "@biomejs/cli-linux-arm64": ["@biomejs/cli-linux-arm64@2.3.2", "", { "os": "linux", "cpu": "arm64" }, "sha512-amnqvk+gWybbQleRRq8TMe0rIv7GHss8mFJEaGuEZYWg1Tw14YKOkeo8h6pf1c+d3qR+JU4iT9KXnBKGON4klw=="], + "@biomejs/cli-linux-arm64": ["@biomejs/cli-linux-arm64@2.3.3", "http://localhost:4873/@biomejs/cli-linux-arm64/-/cli-linux-arm64-2.3.3.tgz", { "os": "linux", "cpu": "arm64" }, "sha512-zeiKwALNB/hax7+LLhCYqhqzlWdTfgE9BGkX2Z8S4VmCYnGFrf2fON/ec6KCos7mra5MDm6fYICsEWN2+HKZhw=="], - "@biomejs/cli-linux-arm64-musl": ["@biomejs/cli-linux-arm64-musl@2.3.2", "", { "os": "linux", "cpu": "arm64" }, "sha512-2Zz4usDG1GTTPQnliIeNx6eVGGP2ry5vE/v39nT73a3cKN6t5H5XxjcEoZZh62uVZvED7hXXikclvI64vZkYqw=="], + "@biomejs/cli-linux-arm64-musl": ["@biomejs/cli-linux-arm64-musl@2.3.3", "http://localhost:4873/@biomejs/cli-linux-arm64-musl/-/cli-linux-arm64-musl-2.3.3.tgz", { "os": "linux", "cpu": "arm64" }, "sha512-KhCDMV+V7Yu72v40ssGJTHuv/j0n7JQ6l0s/c+EMcX5zPYLMLr4XpmI+WXhp4Vfkz0T5Xnh5wbrTBI3f2UTpjQ=="], - "@biomejs/cli-linux-x64": ["@biomejs/cli-linux-x64@2.3.2", "", { "os": "linux", "cpu": "x64" }, "sha512-8BG/vRAhFz1pmuyd24FQPhNeueLqPtwvZk6yblABY2gzL2H8fLQAF/Z2OPIc+BPIVPld+8cSiKY/KFh6k81xfA=="], + "@biomejs/cli-linux-x64": ["@biomejs/cli-linux-x64@2.3.3", "http://localhost:4873/@biomejs/cli-linux-x64/-/cli-linux-x64-2.3.3.tgz", { "os": "linux", "cpu": "x64" }, "sha512-05CjPLbvVVU8J6eaO6iSEoA0FXKy2l6ddL+1h/VpiosCmIp3HxRKLOa1hhC1n+D13Z8g9b1DtnglGtM5U3sTag=="], - "@biomejs/cli-linux-x64-musl": ["@biomejs/cli-linux-x64-musl@2.3.2", "", { "os": "linux", "cpu": "x64" }, "sha512-gzB19MpRdTuOuLtPpFBGrV3Lq424gHyq2lFj8wfX9tvLMLdmA/R9C7k/mqBp/spcbWuHeIEKgEs3RviOPcWGBA=="], + "@biomejs/cli-linux-x64-musl": ["@biomejs/cli-linux-x64-musl@2.3.3", "http://localhost:4873/@biomejs/cli-linux-x64-musl/-/cli-linux-x64-musl-2.3.3.tgz", { "os": "linux", "cpu": "x64" }, "sha512-IyqQ+jYzU5MVy9CK5NV0U+NnUMPUAhYMrB/x4QgL/Dl1MqzBVc61bHeyhLnKM6DSEk73/TQYrk/8/QmVHudLdQ=="], - "@biomejs/cli-win32-arm64": ["@biomejs/cli-win32-arm64@2.3.2", "", { "os": "win32", "cpu": "arm64" }, "sha512-lCruqQlfWjhMlOdyf5pDHOxoNm4WoyY2vZ4YN33/nuZBRstVDuqPPjS0yBkbUlLEte11FbpW+wWSlfnZfSIZvg=="], + "@biomejs/cli-win32-arm64": ["@biomejs/cli-win32-arm64@2.3.3", "http://localhost:4873/@biomejs/cli-win32-arm64/-/cli-win32-arm64-2.3.3.tgz", { "os": "win32", "cpu": "arm64" }, "sha512-NtlLs3pdFqFAQYZjlEHKOwJEn3GEaz7rtR2oCrzaLT2Xt3Cfd55/VvodQ5V+X+KepLa956QJagckJrNL+DmumQ=="], - "@biomejs/cli-win32-x64": ["@biomejs/cli-win32-x64@2.3.2", "", { "os": "win32", "cpu": "x64" }, "sha512-6Ee9P26DTb4D8sN9nXxgbi9Dw5vSOfH98M7UlmkjKB2vtUbrRqCbZiNfryGiwnPIpd6YUoTl7rLVD2/x1CyEHQ=="], + "@biomejs/cli-win32-x64": ["@biomejs/cli-win32-x64@2.3.3", "http://localhost:4873/@biomejs/cli-win32-x64/-/cli-win32-x64-2.3.3.tgz", { "os": "win32", "cpu": "x64" }, "sha512-klJKPPQvUk9Rlp0Dd56gQw/+Wt6uUprHdHWtbDC93f3Iv+knA2tLWpcYoOZJgPV+9s+RBmYv0DGy4mUlr20esg=="], "@bufbuild/protobuf": ["@bufbuild/protobuf@2.5.2", "", {}, "sha512-foZ7qr0IsUBjzWIq+SuBLfdQCpJ1j8cTuNNT4owngTHoN5KsJb8L9t65fzz7SCeSWzescoOil/0ldqiL041ABg=="], @@ -295,56 +294,6 @@ "@emnapi/wasi-threads": ["@emnapi/wasi-threads@1.1.0", "", { "dependencies": { "tslib": "^2.4.0" } }, "sha512-WI0DdZ8xFSbgMjR1sFsKABJ/C5OnRrjT06JXbZKexJGrDuPTzZdDYfFlsgcCXCyf+suG5QU2e/y1Wo2V/OapLQ=="], - "@esbuild/aix-ppc64": ["@esbuild/aix-ppc64@0.25.5", "", { "os": "aix", "cpu": "ppc64" }, "sha512-9o3TMmpmftaCMepOdA5k/yDw8SfInyzWWTjYTFCX3kPSDJMROQTb8jg+h9Cnwnmm1vOzvxN7gIfB5V2ewpjtGA=="], - - "@esbuild/android-arm": ["@esbuild/android-arm@0.25.5", "", { "os": "android", "cpu": "arm" }, "sha512-AdJKSPeEHgi7/ZhuIPtcQKr5RQdo6OO2IL87JkianiMYMPbCtot9fxPbrMiBADOWWm3T2si9stAiVsGbTQFkbA=="], - - "@esbuild/android-arm64": ["@esbuild/android-arm64@0.25.5", "", { "os": "android", "cpu": "arm64" }, "sha512-VGzGhj4lJO+TVGV1v8ntCZWJktV7SGCs3Pn1GRWI1SBFtRALoomm8k5E9Pmwg3HOAal2VDc2F9+PM/rEY6oIDg=="], - - "@esbuild/android-x64": ["@esbuild/android-x64@0.25.5", "", { "os": "android", "cpu": "x64" }, "sha512-D2GyJT1kjvO//drbRT3Hib9XPwQeWd9vZoBJn+bu/lVsOZ13cqNdDeqIF/xQ5/VmWvMduP6AmXvylO/PIc2isw=="], - - "@esbuild/darwin-arm64": ["@esbuild/darwin-arm64@0.25.5", "", { "os": "darwin", "cpu": "arm64" }, "sha512-GtaBgammVvdF7aPIgH2jxMDdivezgFu6iKpmT+48+F8Hhg5J/sfnDieg0aeG/jfSvkYQU2/pceFPDKlqZzwnfQ=="], - - "@esbuild/darwin-x64": ["@esbuild/darwin-x64@0.25.5", "", { "os": "darwin", "cpu": "x64" }, "sha512-1iT4FVL0dJ76/q1wd7XDsXrSW+oLoquptvh4CLR4kITDtqi2e/xwXwdCVH8hVHU43wgJdsq7Gxuzcs6Iq/7bxQ=="], - - "@esbuild/freebsd-arm64": ["@esbuild/freebsd-arm64@0.25.5", "", { "os": "freebsd", "cpu": "arm64" }, "sha512-nk4tGP3JThz4La38Uy/gzyXtpkPW8zSAmoUhK9xKKXdBCzKODMc2adkB2+8om9BDYugz+uGV7sLmpTYzvmz6Sw=="], - - "@esbuild/freebsd-x64": ["@esbuild/freebsd-x64@0.25.5", "", { "os": "freebsd", "cpu": "x64" }, "sha512-PrikaNjiXdR2laW6OIjlbeuCPrPaAl0IwPIaRv+SMV8CiM8i2LqVUHFC1+8eORgWyY7yhQY+2U2fA55mBzReaw=="], - - "@esbuild/linux-arm": ["@esbuild/linux-arm@0.25.5", "", { "os": "linux", "cpu": "arm" }, "sha512-cPzojwW2okgh7ZlRpcBEtsX7WBuqbLrNXqLU89GxWbNt6uIg78ET82qifUy3W6OVww6ZWobWub5oqZOVtwolfw=="], - - "@esbuild/linux-arm64": ["@esbuild/linux-arm64@0.25.5", "", { "os": "linux", "cpu": "arm64" }, "sha512-Z9kfb1v6ZlGbWj8EJk9T6czVEjjq2ntSYLY2cw6pAZl4oKtfgQuS4HOq41M/BcoLPzrUbNd+R4BXFyH//nHxVg=="], - - "@esbuild/linux-ia32": ["@esbuild/linux-ia32@0.25.5", "", { "os": "linux", "cpu": "ia32" }, "sha512-sQ7l00M8bSv36GLV95BVAdhJ2QsIbCuCjh/uYrWiMQSUuV+LpXwIqhgJDcvMTj+VsQmqAHL2yYaasENvJ7CDKA=="], - - "@esbuild/linux-loong64": ["@esbuild/linux-loong64@0.25.5", "", { "os": "linux", "cpu": "none" }, "sha512-0ur7ae16hDUC4OL5iEnDb0tZHDxYmuQyhKhsPBV8f99f6Z9KQM02g33f93rNH5A30agMS46u2HP6qTdEt6Q1kg=="], - - "@esbuild/linux-mips64el": ["@esbuild/linux-mips64el@0.25.5", "", { "os": "linux", "cpu": "none" }, "sha512-kB/66P1OsHO5zLz0i6X0RxlQ+3cu0mkxS3TKFvkb5lin6uwZ/ttOkP3Z8lfR9mJOBk14ZwZ9182SIIWFGNmqmg=="], - - "@esbuild/linux-ppc64": ["@esbuild/linux-ppc64@0.25.5", "", { "os": "linux", "cpu": "ppc64" }, "sha512-UZCmJ7r9X2fe2D6jBmkLBMQetXPXIsZjQJCjgwpVDz+YMcS6oFR27alkgGv3Oqkv07bxdvw7fyB71/olceJhkQ=="], - - "@esbuild/linux-riscv64": ["@esbuild/linux-riscv64@0.25.5", "", { "os": "linux", "cpu": "none" }, "sha512-kTxwu4mLyeOlsVIFPfQo+fQJAV9mh24xL+y+Bm6ej067sYANjyEw1dNHmvoqxJUCMnkBdKpvOn0Ahql6+4VyeA=="], - - "@esbuild/linux-s390x": ["@esbuild/linux-s390x@0.25.5", "", { "os": "linux", "cpu": "s390x" }, "sha512-K2dSKTKfmdh78uJ3NcWFiqyRrimfdinS5ErLSn3vluHNeHVnBAFWC8a4X5N+7FgVE1EjXS1QDZbpqZBjfrqMTQ=="], - - "@esbuild/linux-x64": ["@esbuild/linux-x64@0.25.5", "", { "os": "linux", "cpu": "x64" }, "sha512-uhj8N2obKTE6pSZ+aMUbqq+1nXxNjZIIjCjGLfsWvVpy7gKCOL6rsY1MhRh9zLtUtAI7vpgLMK6DxjO8Qm9lJw=="], - - "@esbuild/netbsd-arm64": ["@esbuild/netbsd-arm64@0.25.5", "", { "os": "none", "cpu": "arm64" }, "sha512-pwHtMP9viAy1oHPvgxtOv+OkduK5ugofNTVDilIzBLpoWAM16r7b/mxBvfpuQDpRQFMfuVr5aLcn4yveGvBZvw=="], - - "@esbuild/netbsd-x64": ["@esbuild/netbsd-x64@0.25.5", "", { "os": "none", "cpu": "x64" }, "sha512-WOb5fKrvVTRMfWFNCroYWWklbnXH0Q5rZppjq0vQIdlsQKuw6mdSihwSo4RV/YdQ5UCKKvBy7/0ZZYLBZKIbwQ=="], - - "@esbuild/openbsd-arm64": ["@esbuild/openbsd-arm64@0.25.5", "", { "os": "openbsd", "cpu": "arm64" }, "sha512-7A208+uQKgTxHd0G0uqZO8UjK2R0DDb4fDmERtARjSHWxqMTye4Erz4zZafx7Di9Cv+lNHYuncAkiGFySoD+Mw=="], - - "@esbuild/openbsd-x64": ["@esbuild/openbsd-x64@0.25.5", "", { "os": "openbsd", "cpu": "x64" }, "sha512-G4hE405ErTWraiZ8UiSoesH8DaCsMm0Cay4fsFWOOUcz8b8rC6uCvnagr+gnioEjWn0wC+o1/TAHt+It+MpIMg=="], - - "@esbuild/sunos-x64": ["@esbuild/sunos-x64@0.25.5", "", { "os": "sunos", "cpu": "x64" }, "sha512-l+azKShMy7FxzY0Rj4RCt5VD/q8mG/e+mDivgspo+yL8zW7qEwctQ6YqKX34DTEleFAvCIUviCFX1SDZRSyMQA=="], - - "@esbuild/win32-arm64": ["@esbuild/win32-arm64@0.25.5", "", { "os": "win32", "cpu": "arm64" }, "sha512-O2S7SNZzdcFG7eFKgvwUEZ2VG9D/sn/eIiz8XRZ1Q/DO5a3s76Xv0mdBzVM5j5R639lXQmPmSo0iRpHqUUrsxw=="], - - "@esbuild/win32-ia32": ["@esbuild/win32-ia32@0.25.5", "", { "os": "win32", "cpu": "ia32" }, "sha512-onOJ02pqs9h1iMJ1PQphR+VZv8qBMQ77Klcsqv9CNW2w6yLqoURLcgERAIurY6QE63bbLuqgP9ATqajFLK5AMQ=="], - - "@esbuild/win32-x64": ["@esbuild/win32-x64@0.25.5", "", { "os": "win32", "cpu": "x64" }, "sha512-TXv6YnJ8ZMVdX+SXWVBo/0p8LTcrUYngpWjvm91TMjjBQii7Oz11Lw5lbDV5Y0TzuhSJHwiH4hEtC1I42mMS0g=="], - "@eslint-community/eslint-utils": ["@eslint-community/eslint-utils@4.9.0", "", { "dependencies": { "eslint-visitor-keys": "^3.4.3" }, "peerDependencies": { "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" } }, "sha512-ayVFHdtZ+hsq1t2Dy24wCmGXGe4q9Gu3smhLYALJrr473ZH27MsnSL+LKUlimp4BWJqMDMLmPpx/Q9R3OAlL4g=="], "@eslint-community/regexpp": ["@eslint-community/regexpp@4.12.1", "", {}, "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ=="], @@ -435,6 +384,10 @@ "@nodelib/fs.walk": ["@nodelib/fs.walk@1.2.8", "", { "dependencies": { "@nodelib/fs.scandir": "2.1.5", "fastq": "^1.6.0" } }, "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg=="], + "@oxc-project/runtime": ["@oxc-project/runtime@0.95.0", "http://localhost:4873/@oxc-project/runtime/-/runtime-0.95.0.tgz", {}, "sha512-qJS5pNepwMGnafO9ayKGz7rfPQgUBuunHpnP1//9Qa0zK3oT3t1EhT+I+pV9MUA+ZKez//OFqxCxf1vijCKb2Q=="], + + "@oxc-project/types": ["@oxc-project/types@0.95.0", "http://localhost:4873/@oxc-project/types/-/types-0.95.0.tgz", {}, "sha512-vACy7vhpMPhjEJhULNxrdR0D943TkA/MigMpJCHmBHvMXxRStRi/dPtTlfQ3uDwWSzRpT8z+7ImjZVf8JWBocQ=="], + "@oxc-resolver/binding-android-arm-eabi": ["@oxc-resolver/binding-android-arm-eabi@11.13.0", "", { "os": "android", "cpu": "arm" }, "sha512-lqaFg5bavNdDoRuQywS66hRk4M12m4kyT3cFpIXfFy6OpobOBeo6R+vJIXl3XRzCmDK58haIYfqTP3KBb3QFgQ=="], "@oxc-resolver/binding-android-arm64": ["@oxc-resolver/binding-android-arm64@11.13.0", "", { "os": "android", "cpu": "arm64" }, "sha512-oLjhpGMKOT8lsqdof2tNSeb4tOi7zAGJHbGBe7pB/75mSDshs/7YbHG+zm35cwecQTBTXf9Ok4/gIbzX3YaRpw=="], @@ -525,6 +478,36 @@ "@reteps/dockerfmt": ["@reteps/dockerfmt@0.3.6", "", {}, "sha512-Tb5wIMvBf/nLejTQ61krK644/CEMB/cpiaIFXqGApfGqO3GwcR3qnI0DbmkFVCl2OyEp8LnLX3EkucoL0+tbFg=="], + "@rolldown/binding-android-arm64": ["@rolldown/binding-android-arm64@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-android-arm64/-/binding-android-arm64-1.0.0-beta.45.tgz", { "os": "android", "cpu": "arm64" }, "sha512-bfgKYhFiXJALeA/riil908+2vlyWGdwa7Ju5S+JgWZYdR4jtiPOGdM6WLfso1dojCh+4ZWeiTwPeV9IKQEX+4g=="], + + "@rolldown/binding-darwin-arm64": ["@rolldown/binding-darwin-arm64@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-darwin-arm64/-/binding-darwin-arm64-1.0.0-beta.45.tgz", { "os": "darwin", "cpu": "arm64" }, "sha512-xjCv4CRVsSnnIxTuyH1RDJl5OEQ1c9JYOwfDAHddjJDxCw46ZX9q80+xq7Eok7KC4bRSZudMJllkvOKv0T9SeA=="], + + "@rolldown/binding-darwin-x64": ["@rolldown/binding-darwin-x64@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-darwin-x64/-/binding-darwin-x64-1.0.0-beta.45.tgz", { "os": "darwin", "cpu": "x64" }, "sha512-ddcO9TD3D/CLUa/l8GO8LHzBOaZqWg5ClMy3jICoxwCuoz47h9dtqPsIeTiB6yR501LQTeDsjA4lIFd7u3Ljfw=="], + + "@rolldown/binding-freebsd-x64": ["@rolldown/binding-freebsd-x64@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-freebsd-x64/-/binding-freebsd-x64-1.0.0-beta.45.tgz", { "os": "freebsd", "cpu": "x64" }, "sha512-MBTWdrzW9w+UMYDUvnEuh0pQvLENkl2Sis15fHTfHVW7ClbGuez+RWopZudIDEGkpZXdeI4CkRXk+vdIIebrmg=="], + + "@rolldown/binding-linux-arm-gnueabihf": ["@rolldown/binding-linux-arm-gnueabihf@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-linux-arm-gnueabihf/-/binding-linux-arm-gnueabihf-1.0.0-beta.45.tgz", { "os": "linux", "cpu": "arm" }, "sha512-4YgoCFiki1HR6oSg+GxxfzfnVCesQxLF1LEnw9uXS/MpBmuog0EOO2rYfy69rWP4tFZL9IWp6KEfGZLrZ7aUog=="], + + "@rolldown/binding-linux-arm64-gnu": ["@rolldown/binding-linux-arm64-gnu@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-linux-arm64-gnu/-/binding-linux-arm64-gnu-1.0.0-beta.45.tgz", { "os": "linux", "cpu": "arm64" }, "sha512-LE1gjAwQRrbCOorJJ7LFr10s5vqYf5a00V5Ea9wXcT2+56n5YosJkcp8eQ12FxRBv2YX8dsdQJb+ZTtYJwb6XQ=="], + + "@rolldown/binding-linux-arm64-musl": ["@rolldown/binding-linux-arm64-musl@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-linux-arm64-musl/-/binding-linux-arm64-musl-1.0.0-beta.45.tgz", { "os": "linux", "cpu": "arm64" }, "sha512-tdy8ThO/fPp40B81v0YK3QC+KODOmzJzSUOO37DinQxzlTJ026gqUSOM8tzlVixRbQJltgVDCTYF8HNPRErQTA=="], + + "@rolldown/binding-linux-x64-gnu": ["@rolldown/binding-linux-x64-gnu@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-linux-x64-gnu/-/binding-linux-x64-gnu-1.0.0-beta.45.tgz", { "os": "linux", "cpu": "x64" }, "sha512-lS082ROBWdmOyVY/0YB3JmsiClaWoxvC+dA8/rbhyB9VLkvVEaihLEOr4CYmrMse151C4+S6hCw6oa1iewox7g=="], + + "@rolldown/binding-linux-x64-musl": ["@rolldown/binding-linux-x64-musl@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-linux-x64-musl/-/binding-linux-x64-musl-1.0.0-beta.45.tgz", { "os": "linux", "cpu": "x64" }, "sha512-Hi73aYY0cBkr1/SvNQqH8Cd+rSV6S9RB5izCv0ySBcRnd/Wfn5plguUoGYwBnhHgFbh6cPw9m2dUVBR6BG1gxA=="], + + "@rolldown/binding-openharmony-arm64": ["@rolldown/binding-openharmony-arm64@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-openharmony-arm64/-/binding-openharmony-arm64-1.0.0-beta.45.tgz", { "os": "none", "cpu": "arm64" }, "sha512-fljEqbO7RHHogNDxYtTzr+GNjlfOx21RUyGmF+NrkebZ8emYYiIqzPxsaMZuRx0rgZmVmliOzEp86/CQFDKhJQ=="], + + "@rolldown/binding-wasm32-wasi": ["@rolldown/binding-wasm32-wasi@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-wasm32-wasi/-/binding-wasm32-wasi-1.0.0-beta.45.tgz", { "dependencies": { "@napi-rs/wasm-runtime": "^1.0.7" }, "cpu": "none" }, "sha512-ZJDB7lkuZE9XUnWQSYrBObZxczut+8FZ5pdanm8nNS1DAo8zsrPuvGwn+U3fwU98WaiFsNrA4XHngesCGr8tEQ=="], + + "@rolldown/binding-win32-arm64-msvc": ["@rolldown/binding-win32-arm64-msvc@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-win32-arm64-msvc/-/binding-win32-arm64-msvc-1.0.0-beta.45.tgz", { "os": "win32", "cpu": "arm64" }, "sha512-zyzAjItHPUmxg6Z8SyRhLdXlJn3/D9KL5b9mObUrBHhWS/GwRH4665xCiFqeuktAhhWutqfc+rOV2LjK4VYQGQ=="], + + "@rolldown/binding-win32-ia32-msvc": ["@rolldown/binding-win32-ia32-msvc@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-win32-ia32-msvc/-/binding-win32-ia32-msvc-1.0.0-beta.45.tgz", { "os": "win32", "cpu": "ia32" }, "sha512-wODcGzlfxqS6D7BR0srkJk3drPwXYLu7jPHN27ce2c4PUnVVmJnp9mJzUQGT4LpmHmmVdMZ+P6hKvyTGBzc1CA=="], + + "@rolldown/binding-win32-x64-msvc": ["@rolldown/binding-win32-x64-msvc@1.0.0-beta.45", "http://localhost:4873/@rolldown/binding-win32-x64-msvc/-/binding-win32-x64-msvc-1.0.0-beta.45.tgz", { "os": "win32", "cpu": "x64" }, "sha512-wiU40G1nQo9rtfvF9jLbl79lUgjfaD/LTyUEw2Wg/gdF5OhjzpKMVugZQngO+RNdwYaNj+Fs+kWBWfp4VXPMHA=="], + + "@rolldown/pluginutils": ["@rolldown/pluginutils@1.0.0-beta.45", "http://localhost:4873/@rolldown/pluginutils/-/pluginutils-1.0.0-beta.45.tgz", {}, "sha512-Le9ulGCrD8ggInzWw/k2J8QcbPz7eGIOWqfJ2L+1R0Opm7n6J37s2hiDWlh6LJN0Lk9L5sUzMvRHKW7UxBZsQA=="], + "@rollup/plugin-inject": ["@rollup/plugin-inject@5.0.5", "", { "dependencies": { "@rollup/pluginutils": "^5.0.1", "estree-walker": "^2.0.2", "magic-string": "^0.30.3" }, "peerDependencies": { "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" }, "optionalPeers": ["rollup"] }, "sha512-2+DEJbNBoPROPkgTDNe8/1YXWcqxbN5DTjASVIOx8HS+pITXushyNiBV56RB08zuptzz8gT3YfkqriTBVycepg=="], "@rollup/pluginutils": ["@rollup/pluginutils@5.2.0", "", { "dependencies": { "@types/estree": "^1.0.0", "estree-walker": "^2.0.2", "picomatch": "^4.0.2" }, "peerDependencies": { "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" }, "optionalPeers": ["rollup"] }, "sha512-qWJ2ZTbmumwiLFomfzTyt5Kng4hwPi9rwCYN4SHb6eaRU1KNO4ccxINHr/VhH4GgPlt1XfSTLX2LBTme8ne4Zw=="], @@ -571,15 +554,15 @@ "@sec-ant/readable-stream": ["@sec-ant/readable-stream@0.4.1", "", {}, "sha512-831qok9r2t8AlxLko40y2ebgSDhenenCatLVeW/uBtnHPyhHOvG0C7TvfgecV+wHzIm5KUICgzmVpWS+IMEAeg=="], - "@sentry-internal/browser-utils": ["@sentry-internal/browser-utils@9.46.0", "", { "dependencies": { "@sentry/core": "9.46.0" } }, "sha512-Q0CeHym9wysku8mYkORXmhtlBE0IrafAI+NiPSqxOBKXGOCWKVCvowHuAF56GwPFic2rSrRnub5fWYv7T1jfEQ=="], + "@sentry-internal/browser-utils": ["@sentry-internal/browser-utils@10.22.0", "http://localhost:4873/@sentry-internal/browser-utils/-/browser-utils-10.22.0.tgz", { "dependencies": { "@sentry/core": "10.22.0" } }, "sha512-BpJoLZEyJr7ORzkCrIjxRTnFWwO1mJNICVh3B9g5d9245niGT4OJvRozmLz89WgJkZFHWu84ls6Xfq5b/3tGFQ=="], - "@sentry-internal/feedback": ["@sentry-internal/feedback@9.46.0", "", { "dependencies": { "@sentry/core": "9.46.0" } }, "sha512-KLRy3OolDkGdPItQ3obtBU2RqDt9+KE8z7r7Gsu7c6A6A89m8ZVlrxee3hPQt6qp0YY0P8WazpedU3DYTtaT8w=="], + "@sentry-internal/feedback": ["@sentry-internal/feedback@10.22.0", "http://localhost:4873/@sentry-internal/feedback/-/feedback-10.22.0.tgz", { "dependencies": { "@sentry/core": "10.22.0" } }, "sha512-zXySOin/gGHPV+yKaHqjN9YZ7psEJwzLn8PzCLeo+4REzF1eQwbYZIgOxJFD32z8s3nZiABSWFM/n1CvVfMEsQ=="], - "@sentry-internal/replay": ["@sentry-internal/replay@9.46.0", "", { "dependencies": { "@sentry-internal/browser-utils": "9.46.0", "@sentry/core": "9.46.0" } }, "sha512-+8JUblxSSnN0FXcmOewbN+wIc1dt6/zaSeAvt2xshrfrLooVullcGsuLAiPhY0d/e++Fk06q1SAl9g4V0V13gg=="], + "@sentry-internal/replay": ["@sentry-internal/replay@10.22.0", "http://localhost:4873/@sentry-internal/replay/-/replay-10.22.0.tgz", { "dependencies": { "@sentry-internal/browser-utils": "10.22.0", "@sentry/core": "10.22.0" } }, "sha512-JNE4kHAQSG4/V+J+Zog3vKBWgOe9H33ol/MEU1RuLM/4I+uLf4mTetwnS9ilpnnW/Z/gQYfA+R3CiMrZtqTivw=="], - "@sentry-internal/replay-canvas": ["@sentry-internal/replay-canvas@9.46.0", "", { "dependencies": { "@sentry-internal/replay": "9.46.0", "@sentry/core": "9.46.0" } }, "sha512-QcBjrdRWFJrrrjbmrr2bbrp2R9RYj1KMEbhHNT2Lm1XplIQw+tULEKOHxNtkUFSLR1RNje7JQbxhzM1j95FxVQ=="], + "@sentry-internal/replay-canvas": ["@sentry-internal/replay-canvas@10.22.0", "http://localhost:4873/@sentry-internal/replay-canvas/-/replay-canvas-10.22.0.tgz", { "dependencies": { "@sentry-internal/replay": "10.22.0", "@sentry/core": "10.22.0" } }, "sha512-DE4JNUskJg+O+wFq42W5gAa/99aD5k7TfGOwABxvnzFv8vkKA7pqXwPbFFPzypdKIkln+df7RmbnDwQRNg6/lA=="], - "@sentry/browser": ["@sentry/browser@9.46.0", "", { "dependencies": { "@sentry-internal/browser-utils": "9.46.0", "@sentry-internal/feedback": "9.46.0", "@sentry-internal/replay": "9.46.0", "@sentry-internal/replay-canvas": "9.46.0", "@sentry/core": "9.46.0" } }, "sha512-NOnCTQCM0NFuwbyt4DYWDNO2zOTj1mCf43hJqGDFb1XM9F++7zAmSNnCx4UrEoBTiFOy40McJwBBk9D1blSktA=="], + "@sentry/browser": ["@sentry/browser@10.22.0", "http://localhost:4873/@sentry/browser/-/browser-10.22.0.tgz", { "dependencies": { "@sentry-internal/browser-utils": "10.22.0", "@sentry-internal/feedback": "10.22.0", "@sentry-internal/replay": "10.22.0", "@sentry-internal/replay-canvas": "10.22.0", "@sentry/core": "10.22.0" } }, "sha512-wD2XqN+yeBpQFfdPo6+wlKDMyyuDctVGzZWE4qTPntICKQuwMdAfeq5Ma89ad0Dw+bzG9UijGeyuJQlswF87Mw=="], "@sentry/core": ["@sentry/core@9.46.0", "", {}, "sha512-it7JMFqxVproAgEtbLgCVBYtQ9fIb+Bu0JD+cEplTN/Ukpe6GaolyYib5geZqslVxhp2sQgT+58aGvfd/k0N8Q=="], @@ -909,8 +892,6 @@ "es-object-atoms": ["es-object-atoms@1.1.1", "", { "dependencies": { "es-errors": "^1.3.0" } }, "sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA=="], - "esbuild": ["esbuild@0.25.5", "", { "optionalDependencies": { "@esbuild/aix-ppc64": "0.25.5", "@esbuild/android-arm": "0.25.5", "@esbuild/android-arm64": "0.25.5", "@esbuild/android-x64": "0.25.5", "@esbuild/darwin-arm64": "0.25.5", "@esbuild/darwin-x64": "0.25.5", "@esbuild/freebsd-arm64": "0.25.5", "@esbuild/freebsd-x64": "0.25.5", "@esbuild/linux-arm": "0.25.5", "@esbuild/linux-arm64": "0.25.5", "@esbuild/linux-ia32": "0.25.5", "@esbuild/linux-loong64": "0.25.5", "@esbuild/linux-mips64el": "0.25.5", "@esbuild/linux-ppc64": "0.25.5", "@esbuild/linux-riscv64": "0.25.5", "@esbuild/linux-s390x": "0.25.5", "@esbuild/linux-x64": "0.25.5", "@esbuild/netbsd-arm64": "0.25.5", "@esbuild/netbsd-x64": "0.25.5", "@esbuild/openbsd-arm64": "0.25.5", "@esbuild/openbsd-x64": "0.25.5", "@esbuild/sunos-x64": "0.25.5", "@esbuild/win32-arm64": "0.25.5", "@esbuild/win32-ia32": "0.25.5", "@esbuild/win32-x64": "0.25.5" }, "bin": { "esbuild": "bin/esbuild" } }, "sha512-P8OtKZRv/5J5hhz0cUAdu/cLuPIKXpQl1R9pZtvmHWQvrAUVd0UNIPT4IB4W3rNOqVO0rlqHmCIbSwxh/c9yUQ=="], - "escalade": ["escalade@3.2.0", "", {}, "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA=="], "escape-string-regexp": ["escape-string-regexp@4.0.0", "", {}, "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA=="], @@ -1133,12 +1114,16 @@ "kind-of": ["kind-of@6.0.3", "", {}, "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw=="], - "knip": ["knip@5.67.0", "", { "dependencies": { "@nodelib/fs.walk": "^1.2.3", "fast-glob": "^3.3.3", "formatly": "^0.3.0", "jiti": "^2.6.0", "js-yaml": "^4.1.0", "minimist": "^1.2.8", "oxc-resolver": "^11.12.0", "picocolors": "^1.1.1", "picomatch": "^4.0.1", "smol-toml": "^1.4.1", "strip-json-comments": "5.0.2", "zod": "^4.1.11" }, "peerDependencies": { "@types/node": ">=18", "typescript": ">=5.0.4 <7" }, "bin": { "knip": "bin/knip.js", "knip-bun": "bin/knip-bun.js" } }, "sha512-zVa7bUx4dPN2xqxCidz48C+74io9l43YQ6YjxBeMcYjIRjOZ8UTbB3FZhfrb+71QETxacYlfGCg0MPMpXZUKQw=="], + "knip": ["knip@5.67.1", "http://localhost:4873/knip/-/knip-5.67.1.tgz", { "dependencies": { "@nodelib/fs.walk": "^1.2.3", "fast-glob": "^3.3.3", "formatly": "^0.3.0", "jiti": "^2.6.0", "js-yaml": "^4.1.0", "minimist": "^1.2.8", "oxc-resolver": "^11.12.0", "picocolors": "^1.1.1", "picomatch": "^4.0.1", "smol-toml": "^1.4.1", "strip-json-comments": "5.0.2", "zod": "^4.1.11" }, "peerDependencies": { "@types/node": ">=18", "typescript": ">=5.0.4 <7" }, "bin": { "knip": "bin/knip.js", "knip-bun": "bin/knip-bun.js" } }, "sha512-U5AtiqnZAbWIxihs5wxFFEZlpKhzRLWlXSGwA79na7wvlX+MsE0rSuU6If+kl/A4o3TDzTtKGZ4SjeLyWkNR/A=="], "known-css-properties": ["known-css-properties@0.37.0", "", {}, "sha512-JCDrsP4Z1Sb9JwG0aJ8Eo2r7k4Ou5MwmThS/6lcIe1ICyb7UBJKGRIUUdqc2ASdE/42lgz6zFUnzAIhtXnBVrQ=="], "levn": ["levn@0.4.1", "", { "dependencies": { "prelude-ls": "^1.2.1", "type-check": "~0.4.0" } }, "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ=="], + "lightningcss": ["lightningcss@1.30.2", "http://localhost:4873/lightningcss/-/lightningcss-1.30.2.tgz", { "dependencies": { "detect-libc": "^2.0.3" }, "optionalDependencies": { "lightningcss-android-arm64": "1.30.2", "lightningcss-darwin-arm64": "1.30.2", "lightningcss-darwin-x64": "1.30.2", "lightningcss-freebsd-x64": "1.30.2", "lightningcss-linux-arm-gnueabihf": "1.30.2", "lightningcss-linux-arm64-gnu": "1.30.2", "lightningcss-linux-arm64-musl": "1.30.2", "lightningcss-linux-x64-gnu": "1.30.2", "lightningcss-linux-x64-musl": "1.30.2", "lightningcss-win32-arm64-msvc": "1.30.2", "lightningcss-win32-x64-msvc": "1.30.2" } }, "sha512-utfs7Pr5uJyyvDETitgsaqSyjCb2qNRAtuqUeWIAKztsOYdcACf2KtARYXg2pSvhkt+9NfoaNY7fxjl6nuMjIQ=="], + + "lightningcss-android-arm64": ["lightningcss-android-arm64@1.30.2", "http://localhost:4873/lightningcss-android-arm64/-/lightningcss-android-arm64-1.30.2.tgz", { "os": "android", "cpu": "arm64" }, "sha512-BH9sEdOCahSgmkVhBLeU7Hc9DWeZ1Eb6wNS6Da8igvUwAe0sqROHddIlvU06q3WyXVEOYDZ6ykBZQnjTbmo4+A=="], + "lightningcss-cli": ["lightningcss-cli@1.30.2", "", { "dependencies": { "detect-libc": "^2.0.3" }, "optionalDependencies": { "lightningcss-cli-android-arm64": "1.30.2", "lightningcss-cli-darwin-arm64": "1.30.2", "lightningcss-cli-darwin-x64": "1.30.2", "lightningcss-cli-freebsd-x64": "1.30.2", "lightningcss-cli-linux-arm-gnueabihf": "1.30.2", "lightningcss-cli-linux-arm64-gnu": "1.30.2", "lightningcss-cli-linux-arm64-musl": "1.30.2", "lightningcss-cli-linux-x64-gnu": "1.30.2", "lightningcss-cli-linux-x64-musl": "1.30.2", "lightningcss-cli-win32-arm64-msvc": "1.30.2", "lightningcss-cli-win32-x64-msvc": "1.30.2" }, "bin": { "lightningcss": "lightningcss" } }, "sha512-vTm/775SqvQ74T0y4twiqjopXV6SnAFguuRpnbKUE9aXxqJGxWJoHS77ZRkJj3dKmnD61ejOawg3FBiTT8/3Tw=="], "lightningcss-cli-android-arm64": ["lightningcss-cli-android-arm64@1.30.2", "", { "os": "android", "cpu": "arm64" }, "sha512-CcntRK9yNjFRiZKwW9m4sf5WYYNOGxlD4ROymyIb+KPbsrEBAZSaknoUM1aIhuhvB/TUTtVmPKvt/Zu0LeSR7g=="], @@ -1163,6 +1148,26 @@ "lightningcss-cli-win32-x64-msvc": ["lightningcss-cli-win32-x64-msvc@1.30.2", "", { "os": "win32", "cpu": "x64" }, "sha512-5VUIS1Dcbkcy2SDr7vBlKfwpSx2BUlZwmvoRVWA+OkkLsQhVUtLUKheJJXsOFruBn9uV8FH8KPLkvTJzuGFLyQ=="], + "lightningcss-darwin-arm64": ["lightningcss-darwin-arm64@1.30.2", "http://localhost:4873/lightningcss-darwin-arm64/-/lightningcss-darwin-arm64-1.30.2.tgz", { "os": "darwin", "cpu": "arm64" }, "sha512-ylTcDJBN3Hp21TdhRT5zBOIi73P6/W0qwvlFEk22fkdXchtNTOU4Qc37SkzV+EKYxLouZ6M4LG9NfZ1qkhhBWA=="], + + "lightningcss-darwin-x64": ["lightningcss-darwin-x64@1.30.2", "http://localhost:4873/lightningcss-darwin-x64/-/lightningcss-darwin-x64-1.30.2.tgz", { "os": "darwin", "cpu": "x64" }, "sha512-oBZgKchomuDYxr7ilwLcyms6BCyLn0z8J0+ZZmfpjwg9fRVZIR5/GMXd7r9RH94iDhld3UmSjBM6nXWM2TfZTQ=="], + + "lightningcss-freebsd-x64": ["lightningcss-freebsd-x64@1.30.2", "http://localhost:4873/lightningcss-freebsd-x64/-/lightningcss-freebsd-x64-1.30.2.tgz", { "os": "freebsd", "cpu": "x64" }, "sha512-c2bH6xTrf4BDpK8MoGG4Bd6zAMZDAXS569UxCAGcA7IKbHNMlhGQ89eRmvpIUGfKWNVdbhSbkQaWhEoMGmGslA=="], + + "lightningcss-linux-arm-gnueabihf": ["lightningcss-linux-arm-gnueabihf@1.30.2", "http://localhost:4873/lightningcss-linux-arm-gnueabihf/-/lightningcss-linux-arm-gnueabihf-1.30.2.tgz", { "os": "linux", "cpu": "arm" }, "sha512-eVdpxh4wYcm0PofJIZVuYuLiqBIakQ9uFZmipf6LF/HRj5Bgm0eb3qL/mr1smyXIS1twwOxNWndd8z0E374hiA=="], + + "lightningcss-linux-arm64-gnu": ["lightningcss-linux-arm64-gnu@1.30.2", "http://localhost:4873/lightningcss-linux-arm64-gnu/-/lightningcss-linux-arm64-gnu-1.30.2.tgz", { "os": "linux", "cpu": "arm64" }, "sha512-UK65WJAbwIJbiBFXpxrbTNArtfuznvxAJw4Q2ZGlU8kPeDIWEX1dg3rn2veBVUylA2Ezg89ktszWbaQnxD/e3A=="], + + "lightningcss-linux-arm64-musl": ["lightningcss-linux-arm64-musl@1.30.2", "http://localhost:4873/lightningcss-linux-arm64-musl/-/lightningcss-linux-arm64-musl-1.30.2.tgz", { "os": "linux", "cpu": "arm64" }, "sha512-5Vh9dGeblpTxWHpOx8iauV02popZDsCYMPIgiuw97OJ5uaDsL86cnqSFs5LZkG3ghHoX5isLgWzMs+eD1YzrnA=="], + + "lightningcss-linux-x64-gnu": ["lightningcss-linux-x64-gnu@1.30.2", "http://localhost:4873/lightningcss-linux-x64-gnu/-/lightningcss-linux-x64-gnu-1.30.2.tgz", { "os": "linux", "cpu": "x64" }, "sha512-Cfd46gdmj1vQ+lR6VRTTadNHu6ALuw2pKR9lYq4FnhvgBc4zWY1EtZcAc6EffShbb1MFrIPfLDXD6Xprbnni4w=="], + + "lightningcss-linux-x64-musl": ["lightningcss-linux-x64-musl@1.30.2", "http://localhost:4873/lightningcss-linux-x64-musl/-/lightningcss-linux-x64-musl-1.30.2.tgz", { "os": "linux", "cpu": "x64" }, "sha512-XJaLUUFXb6/QG2lGIW6aIk6jKdtjtcffUT0NKvIqhSBY3hh9Ch+1LCeH80dR9q9LBjG3ewbDjnumefsLsP6aiA=="], + + "lightningcss-win32-arm64-msvc": ["lightningcss-win32-arm64-msvc@1.30.2", "http://localhost:4873/lightningcss-win32-arm64-msvc/-/lightningcss-win32-arm64-msvc-1.30.2.tgz", { "os": "win32", "cpu": "arm64" }, "sha512-FZn+vaj7zLv//D/192WFFVA0RgHawIcHqLX9xuWiQt7P0PtdFEVaxgF9rjM/IRYHQXNnk61/H/gb2Ei+kUQ4xQ=="], + + "lightningcss-win32-x64-msvc": ["lightningcss-win32-x64-msvc@1.30.2", "http://localhost:4873/lightningcss-win32-x64-msvc/-/lightningcss-win32-x64-msvc-1.30.2.tgz", { "os": "win32", "cpu": "x64" }, "sha512-5g1yc73p+iAkid5phb4oVFMB45417DkRevRbt/El/gKXJk4jid+vPFF/AXbxn05Aky8PapwzZrdJShv5C0avjw=="], + "lines-and-columns": ["lines-and-columns@1.2.4", "", {}, "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg=="], "linguist-languages": ["linguist-languages@8.2.0", "", {}, "sha512-KCUUH9x97QWYU0SXOCGxUrZR6cSfuQrMhABB7L/0I8N0LXOeaKe7+RZs7FAwvWCV2qKfZ4Wv1luLq4OfMezSJg=="], @@ -1387,6 +1392,8 @@ "ripemd160": ["ripemd160@2.0.2", "", { "dependencies": { "hash-base": "^3.0.0", "inherits": "^2.0.1" } }, "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA=="], + "rolldown": ["rolldown@1.0.0-beta.45", "http://localhost:4873/rolldown/-/rolldown-1.0.0-beta.45.tgz", { "dependencies": { "@oxc-project/types": "=0.95.0", "@rolldown/pluginutils": "1.0.0-beta.45" }, "optionalDependencies": { "@rolldown/binding-android-arm64": "1.0.0-beta.45", "@rolldown/binding-darwin-arm64": "1.0.0-beta.45", "@rolldown/binding-darwin-x64": "1.0.0-beta.45", "@rolldown/binding-freebsd-x64": "1.0.0-beta.45", "@rolldown/binding-linux-arm-gnueabihf": "1.0.0-beta.45", "@rolldown/binding-linux-arm64-gnu": "1.0.0-beta.45", "@rolldown/binding-linux-arm64-musl": "1.0.0-beta.45", "@rolldown/binding-linux-x64-gnu": "1.0.0-beta.45", "@rolldown/binding-linux-x64-musl": "1.0.0-beta.45", "@rolldown/binding-openharmony-arm64": "1.0.0-beta.45", "@rolldown/binding-wasm32-wasi": "1.0.0-beta.45", "@rolldown/binding-win32-arm64-msvc": "1.0.0-beta.45", "@rolldown/binding-win32-ia32-msvc": "1.0.0-beta.45", "@rolldown/binding-win32-x64-msvc": "1.0.0-beta.45" }, "bin": { "rolldown": "bin/cli.mjs" } }, "sha512-iMmuD72XXLf26Tqrv1cryNYLX6NNPLhZ3AmNkSf8+xda0H+yijjGJ+wVT9UdBUHOpKzq9RjKtQKRCWoEKQQBZQ=="], + "rollup": ["rollup@4.44.0", "", { "dependencies": { "@types/estree": "1.0.8" }, "optionalDependencies": { "@rollup/rollup-android-arm-eabi": "4.44.0", "@rollup/rollup-android-arm64": "4.44.0", "@rollup/rollup-darwin-arm64": "4.44.0", "@rollup/rollup-darwin-x64": "4.44.0", "@rollup/rollup-freebsd-arm64": "4.44.0", "@rollup/rollup-freebsd-x64": "4.44.0", "@rollup/rollup-linux-arm-gnueabihf": "4.44.0", "@rollup/rollup-linux-arm-musleabihf": "4.44.0", "@rollup/rollup-linux-arm64-gnu": "4.44.0", "@rollup/rollup-linux-arm64-musl": "4.44.0", "@rollup/rollup-linux-loongarch64-gnu": "4.44.0", "@rollup/rollup-linux-powerpc64le-gnu": "4.44.0", "@rollup/rollup-linux-riscv64-gnu": "4.44.0", "@rollup/rollup-linux-riscv64-musl": "4.44.0", "@rollup/rollup-linux-s390x-gnu": "4.44.0", "@rollup/rollup-linux-x64-gnu": "4.44.0", "@rollup/rollup-linux-x64-musl": "4.44.0", "@rollup/rollup-win32-arm64-msvc": "4.44.0", "@rollup/rollup-win32-ia32-msvc": "4.44.0", "@rollup/rollup-win32-x64-msvc": "4.44.0", "fsevents": "~2.3.2" }, "bin": { "rollup": "dist/bin/rollup" } }, "sha512-qHcdEzLCiktQIfwBq420pn2dP+30uzqYxv9ETm91wdt2R9AFcWfjNAmje4NWlnCIQ5RMTzVf0ZyisOKqHR6RwA=="], "run-parallel": ["run-parallel@1.2.0", "", { "dependencies": { "queue-microtask": "^1.2.2" } }, "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA=="], @@ -1609,7 +1616,7 @@ "varint": ["varint@6.0.0", "", {}, "sha512-cXEIW6cfr15lFv563k4GuVuW/fiwjknytD37jIOLSdSWuOI6WnO/oKwmP2FQTU2l01LP8/M5TSAJpzUaGe3uWg=="], - "vite": ["vite@7.1.12", "", { "dependencies": { "esbuild": "^0.25.0", "fdir": "^6.5.0", "picomatch": "^4.0.3", "postcss": "^8.5.6", "rollup": "^4.43.0", "tinyglobby": "^0.2.15" }, "optionalDependencies": { "fsevents": "~2.3.3" }, "peerDependencies": { "@types/node": "^20.19.0 || >=22.12.0", "jiti": ">=1.21.0", "less": "^4.0.0", "lightningcss": "^1.21.0", "sass": "^1.70.0", "sass-embedded": "^1.70.0", "stylus": ">=0.54.8", "sugarss": "^5.0.0", "terser": "^5.16.0", "tsx": "^4.8.1", "yaml": "^2.4.2" }, "optionalPeers": ["@types/node", "jiti", "less", "lightningcss", "sass", "sass-embedded", "stylus", "sugarss", "terser", "tsx", "yaml"], "bin": { "vite": "bin/vite.js" } }, "sha512-ZWyE8YXEXqJrrSLvYgrRP7p62OziLW7xI5HYGWFzOvupfAlrLvURSzv/FyGyy0eidogEM3ujU+kUG1zuHgb6Ug=="], + "vite": ["rolldown-vite@7.1.20", "http://localhost:4873/rolldown-vite/-/rolldown-vite-7.1.20.tgz", { "dependencies": { "@oxc-project/runtime": "0.95.0", "fdir": "^6.5.0", "lightningcss": "^1.30.2", "picomatch": "^4.0.3", "postcss": "^8.5.6", "rolldown": "1.0.0-beta.45", "tinyglobby": "^0.2.15" }, "optionalDependencies": { "fsevents": "~2.3.3" }, "peerDependencies": { "@types/node": "^20.19.0 || >=22.12.0", "esbuild": "^0.25.0", "jiti": ">=1.21.0", "less": "^4.0.0", "sass": "^1.70.0", "sass-embedded": "^1.70.0", "stylus": ">=0.54.8", "sugarss": "^5.0.0", "terser": "^5.16.0", "tsx": "^4.8.1", "yaml": "^2.4.2" }, "optionalPeers": ["@types/node", "esbuild", "jiti", "less", "sass", "sass-embedded", "stylus", "sugarss", "terser", "tsx", "yaml"], "bin": { "vite": "bin/vite.js" } }, "sha512-iXo6JzhBnNl+MY5Wky2Qr4RnB1gLJ3798YUMC3uBXSjCDM/bV+ALcnm5M23eOy9Nldi18aUioLpTB/PtqvwSZQ=="], "vite-plugin-compression2": ["vite-plugin-compression2@2.3.1", "", { "dependencies": { "@rollup/pluginutils": "^5.1.0", "tar-mini": "^0.2.0" } }, "sha512-bnhLTsurtvOiiP6EMISIKVsOMCeTAjE6FJbyqQus3W4mtAxF7pCuC4puUIAiCgNs98tOCpqo6GIXJXTLufzIaw=="], @@ -1741,6 +1748,16 @@ "@rollup/pluginutils/picomatch": ["picomatch@4.0.2", "", {}, "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg=="], + "@sentry-internal/browser-utils/@sentry/core": ["@sentry/core@10.22.0", "http://localhost:4873/@sentry/core/-/core-10.22.0.tgz", {}, "sha512-V1oeHbrOKzxadsCmgtPku3v3Emo/Bpb3VSuKmlLrQefiHX98MWtjJ3XDGfduzD5/dCdh0r/OOLwjcmrO/PZ2aw=="], + + "@sentry-internal/feedback/@sentry/core": ["@sentry/core@10.22.0", "http://localhost:4873/@sentry/core/-/core-10.22.0.tgz", {}, "sha512-V1oeHbrOKzxadsCmgtPku3v3Emo/Bpb3VSuKmlLrQefiHX98MWtjJ3XDGfduzD5/dCdh0r/OOLwjcmrO/PZ2aw=="], + + "@sentry-internal/replay/@sentry/core": ["@sentry/core@10.22.0", "http://localhost:4873/@sentry/core/-/core-10.22.0.tgz", {}, "sha512-V1oeHbrOKzxadsCmgtPku3v3Emo/Bpb3VSuKmlLrQefiHX98MWtjJ3XDGfduzD5/dCdh0r/OOLwjcmrO/PZ2aw=="], + + "@sentry-internal/replay-canvas/@sentry/core": ["@sentry/core@10.22.0", "http://localhost:4873/@sentry/core/-/core-10.22.0.tgz", {}, "sha512-V1oeHbrOKzxadsCmgtPku3v3Emo/Bpb3VSuKmlLrQefiHX98MWtjJ3XDGfduzD5/dCdh0r/OOLwjcmrO/PZ2aw=="], + + "@sentry/browser/@sentry/core": ["@sentry/core@10.22.0", "http://localhost:4873/@sentry/core/-/core-10.22.0.tgz", {}, "sha512-V1oeHbrOKzxadsCmgtPku3v3Emo/Bpb3VSuKmlLrQefiHX98MWtjJ3XDGfduzD5/dCdh0r/OOLwjcmrO/PZ2aw=="], + "@stylistic/stylelint-plugin/@csstools/media-query-list-parser": ["@csstools/media-query-list-parser@3.0.1", "", { "peerDependencies": { "@csstools/css-parser-algorithms": "^3.0.1", "@csstools/css-tokenizer": "^3.0.1" } }, "sha512-HNo8gGD02kHmcbX6PvCoUuOQvn4szyB9ca63vZHKX5A81QytgDG4oxG4IaEfHTlEZSZ6MjPEMWIVU+zF2PZcgw=="], "@stylistic/stylelint-plugin/postcss-selector-parser": ["postcss-selector-parser@6.1.2", "", { "dependencies": { "cssesc": "^3.0.0", "util-deprecate": "^1.0.2" } }, "sha512-Q8qQfPiZ+THO/3ZrOrO0cJJKfpYCagtMUkXbnEfmgUjwXg6z/WBeOyS9APBBPCTSiDV+s4SwQGu8yFsiMRIudg=="], diff --git a/composer.json b/composer.json index 1d3b2c4a..f325b8be 100755 --- a/composer.json +++ b/composer.json @@ -41,7 +41,6 @@ "wpackagist-plugin/force-regenerate-thumbnails": "^2.2.1", "wpackagist-plugin/query-monitor": "^3.17.0", "wpackagist-plugin/redis-cache": "^2.5.4", - "wpackagist-plugin/wc-multishipping": "^2.5.4", "wpackagist-plugin/woo-preview-emails": "^2.2.13", "wpackagist-plugin/woocommerce": "^10", "wpackagist-plugin/wp-mail-logging": "^1.13.1", @@ -53,7 +52,7 @@ "phpstan/extension-installer": "^1.4.3", "phpstan/phpstan": "^2.0.3", "roave/security-advisories": "dev-latest", - "squizlabs/php_codesniffer": "^3.11.1", + "squizlabs/php_codesniffer": "^4", "szepeviktor/phpstan-wordpress": "2.x-dev" }, "config": { diff --git a/composer.lock b/composer.lock index b6fdce6e..dd72567d 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "a09d318994212b9f48dfad3bd997211b", + "content-hash": "c56a2e0f435570c60a5c22400c9e46ad", "packages": [ { "name": "brick/math", @@ -3564,24 +3564,6 @@ "type": "wordpress-plugin", "homepage": "https://wordpress.org/plugins/redis-cache/" }, - { - "name": "wpackagist-plugin/wc-multishipping", - "version": "2.5.9", - "source": { - "type": "svn", - "url": "https://plugins.svn.wordpress.org/wc-multishipping/", - "reference": "tags/2.5.9" - }, - "dist": { - "type": "zip", - "url": "https://downloads.wordpress.org/plugin/wc-multishipping.2.5.9.zip" - }, - "require": { - "composer/installers": "^1.0 || ^2.0" - }, - "type": "wordpress-plugin", - "homepage": "https://wordpress.org/plugins/wc-multishipping/" - }, { "name": "wpackagist-plugin/woo-preview-emails", "version": "2.2.14", @@ -4837,37 +4819,32 @@ }, { "name": "squizlabs/php_codesniffer", - "version": "3.13.4", + "version": "4.0.0", "source": { "type": "git", "url": "https://github.com/PHPCSStandards/PHP_CodeSniffer.git", - "reference": "ad545ea9c1b7d270ce0fc9cbfb884161cd706119" + "reference": "06113cfdaf117fc2165f9cd040bd0f17fcd5242d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/PHPCSStandards/PHP_CodeSniffer/zipball/ad545ea9c1b7d270ce0fc9cbfb884161cd706119", - "reference": "ad545ea9c1b7d270ce0fc9cbfb884161cd706119", + "url": "https://api.github.com/repos/PHPCSStandards/PHP_CodeSniffer/zipball/06113cfdaf117fc2165f9cd040bd0f17fcd5242d", + "reference": "06113cfdaf117fc2165f9cd040bd0f17fcd5242d", "shasum": "" }, "require": { "ext-simplexml": "*", "ext-tokenizer": "*", "ext-xmlwriter": "*", - "php": ">=5.4.0" + "php": ">=7.2.0" }, "require-dev": { - "phpunit/phpunit": "^4.0 || ^5.0 || ^6.0 || ^7.0 || ^8.0 || ^9.3.4" + "phpunit/phpunit": "^8.4.0 || ^9.3.4 || ^10.5.32 || 11.3.3 - 11.5.28 || ^11.5.31" }, "bin": [ "bin/phpcbf", "bin/phpcs" ], "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.x-dev" - } - }, "notification-url": "https://packagist.org/downloads/", "license": [ "BSD-3-Clause" @@ -4886,7 +4863,7 @@ "homepage": "https://github.com/PHPCSStandards/PHP_CodeSniffer/graphs/contributors" } ], - "description": "PHP_CodeSniffer tokenizes PHP, JavaScript and CSS files and detects violations of a defined set of coding standards.", + "description": "PHP_CodeSniffer tokenizes PHP files and detects violations of a defined set of coding standards.", "homepage": "https://github.com/PHPCSStandards/PHP_CodeSniffer", "keywords": [ "phpcs", @@ -4917,7 +4894,7 @@ "type": "thanks_dev" } ], - "time": "2025-09-05T05:47:09+00:00" + "time": "2025-09-15T11:28:58+00:00" }, { "name": "szepeviktor/phpstan-wordpress", diff --git a/justfile b/justfile index b54fed44..f2076130 100755 --- a/justfile +++ b/justfile @@ -24,7 +24,7 @@ update: [group('qualité')] format: @echo "Formatage de l'ensemble du code avec Prettier et dprint." - bunx prettier \ + bun prettier \ --cache \ --cache-location "{{ cacheFolder }}/{{ prettierCacheFile }}" \ --ignore-unknown \ @@ -35,40 +35,40 @@ format: # Compile, minifie et optimise Sass vers CSS. [group('css')] build-css: - @bunx sass \ + @bun sass \ --update \ "web/app/themes/haiku-atelier-2024/src/sass":"web/app/themes/haiku-atelier-2024/assets/css" - @bunx lightningcss \ + @bun lightningcss \ --bundle \ --minify \ --output-file "web/app/themes/haiku-atelier-2024/assets/css/main.min.css" \ -- "web/app/themes/haiku-atelier-2024/assets/css/main.css" - @bunx lightningcss \ + @bun lightningcss \ --bundle \ --minify \ --output-file "web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.min.css" \ -- "web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css" - @bunx lightningcss \ + @bun lightningcss \ --bundle \ --minify \ --output-file "web/app/themes/haiku-atelier-2024/assets/css/pages/page-accueil.min.css" \ -- "web/app/themes/haiku-atelier-2024/assets/css/pages/page-accueil.css" - @bunx lightningcss \ + @bun lightningcss \ --bundle \ --minify \ --output-file "web/app/themes/haiku-atelier-2024/assets/css/pages/page-boutique.min.css" \ -- "web/app/themes/haiku-atelier-2024/assets/css/pages/page-boutique.css" - @bunx lightningcss \ + @bun lightningcss \ --bundle \ --minify \ --output-file "web/app/themes/haiku-atelier-2024/assets/css/pages/page-a-propos.min.css" \ -- "web/app/themes/haiku-atelier-2024/assets/css/pages/page-a-propos.css" - @bunx lightningcss \ + @bun lightningcss \ --bundle \ --minify \ --output-file "web/app/themes/haiku-atelier-2024/assets/css/pages/page-modele-simple.min.css" \ -- "web/app/themes/haiku-atelier-2024/assets/css/pages/page-modele-simple.css" - @bunx lightningcss \ + @bun lightningcss \ --bundle \ --minify \ --output-file "web/app/themes/haiku-atelier-2024/assets/css/pages/page-succes-commande.min.css" \ @@ -83,7 +83,7 @@ watch-css: # Compile TypeScript en JavaScript. [group('js')] build-js: - @bunx vite build + @bun vite build # Compile tout. [group('css')] @@ -96,27 +96,27 @@ build-all: # Compile TypeScript à chaque changement de fichier. [group('js')] watch-js: - bunx vite build --watch + bun vite build --watch # Vérifie le code TypeScript avec des analyseurs statiques. [group('js')] [group('qualité')] lint-js: - -bunx eslint "web/app/themes/haiku-atelier-2024/src/scripts" - -bunx biome check --reporter=summary "web/app/themes/haiku-atelier-2024/src/scripts" - -bunx oxlint "web/app/themes/haiku-atelier-2024/src/scripts" + -bun eslint "web/app/themes/haiku-atelier-2024/src/scripts" + -bun biome check --reporter=summary "web/app/themes/haiku-atelier-2024/src/scripts" + -bun oxlint "web/app/themes/haiku-atelier-2024/src/scripts" # Vérifie le code Sass avec Stylelint. [group('css')] [group('qualité')] lint-css: - -bunx stylelint "web/app/themes/haiku-atelier-2024/src/sass/" --fix + -bun stylelint "web/app/themes/haiku-atelier-2024/src/sass/" --fix # Vérifie le code TypeScript mort avec knip [group('js')] [group('qualité')] lint-code-mort: - -bunx knip + -bun knip # Fusionne tous les changements actuels dans le commit précédent et pousse sur le répertoire distant avec Jujetsu. [group('vcs')] diff --git a/package.json b/package.json index 1ccfb77e..82ef85f7 100755 --- a/package.json +++ b/package.json @@ -7,13 +7,11 @@ "license": "ISC", "main": "index.js", "keywords": [], - "scripts": { - "knip": "knip" - }, + "scripts": { "knip": "knip" }, "dependencies": { "@logtape/logtape": "^1.1.2", "@mobily/ts-belt": "v4.0.0-rc.5", - "@sentry/browser": "^9.46.0", + "@sentry/browser": "^10.22.0", "a11y-dialog": "^8.1.4", "chalk": "^5.6.2", "lit-html": "^3.3.1", @@ -25,7 +23,7 @@ "valibot": "1.1.0" }, "devDependencies": { - "@biomejs/biome": "^2.3.2", + "@biomejs/biome": "^2.3.3", "@cspell/dict-fr-fr": "^2.3.2", "@eslint/js": "^9.39.0", "@playwright/test": "^1.56.1", @@ -44,7 +42,7 @@ "eslint-plugin-perfectionist": "^4.15.1", "fdir": "^6.5.0", "globals": "^16.5.0", - "knip": "^5.67.0", + "knip": "^5.67.1", "lightningcss-cli": "^1.30.2", "oxlint": "^1.25.0", "picomatch": "^4.0.3", @@ -61,7 +59,7 @@ "stylelint-plugin-logical-css": "^1.2.3", "typescript": "5.9.3", "typescript-eslint": "^8.46.2", - "vite": "^7.1.12", + "vite": "npm:rolldown-vite@latest", "vite-plugin-compression2": "^2.3.1", "vite-plugin-manifest-sri": "^0.2.0", "vite-plugin-node-polyfills": "^0.24.0", diff --git a/tsconfig.json b/tsconfig.json index 69672e61..fbb77606 100755 --- a/tsconfig.json +++ b/tsconfig.json @@ -44,5 +44,5 @@ "useUnknownInCatchVariables": true }, "exclude": ["vendor", "web/app/plugins", "web/wp"], - "include": ["*.js", "lib", "web/app/themes/haiku-atelier-2024/src"] + "include": ["*.js", "lib", "web/app/themes/haiku-atelier-2024/src", "vite.config.ts"] } diff --git a/vite.config.js b/vite.config.ts similarity index 88% rename from vite.config.js rename to vite.config.ts index 2f5a2707..2e5b1b41 100755 --- a/vite.config.js +++ b/vite.config.ts @@ -1,5 +1,5 @@ import legacy from "@vitejs/plugin-legacy"; -import { fdir } from "fdir"; +import { fdir, PathsOutput } from "fdir"; import { resolve } from "node:path"; import process from "node:process"; import * as v from "valibot"; @@ -10,7 +10,7 @@ import { nodePolyfills } from "vite-plugin-node-polyfills"; import valibot from "vite-plugin-valibot-env"; const SLUG_THEME = "haiku-atelier-2024"; -const SRC_TYPESCRIPT_PATHS = new fdir() +const SRC_TYPESCRIPT_PATHS: Promise = new fdir() .withBasePath() .filter((path, isDirectory) => !isDirectory && !path.endsWith("d.ts")) .withMaxDepth(0) @@ -53,6 +53,7 @@ const prodPlugins = [ export default defineConfig(async ({ mode }) => { const env = loadEnv(mode, process.cwd(), "VITE"); + console.debug(env); return { base: "/", @@ -66,16 +67,19 @@ export default defineConfig(async ({ mode }) => { reportCompressedSize: true, rollupOptions: { input: await SRC_TYPESCRIPT_PATHS, + experimental: { + incrementalBuild: true, + nativeMagicString: true, + }, output: { assetFileNames: "[name].[hash].[extname]", chunkFileNames: "[name].[hash].js", - compact: env["VITE_MODE"] === "production", entryFileNames: "[name].js", - validate: true, + minify: env["VITE_MODE"] === "production", }, treeshake: true, }, - sourcemap: env["VITE_MODE"] === "production", + sourcemap: env["VITE_MODE"] === "development", target: "es2020", write: true, }, diff --git a/web/app/themes/haiku-atelier-2024/assets/css/main.css b/web/app/themes/haiku-atelier-2024/assets/css/main.css index 9f4e6041..052b6ce3 100755 --- a/web/app/themes/haiku-atelier-2024/assets/css/main.css +++ b/web/app/themes/haiku-atelier-2024/assets/css/main.css @@ -67,7 +67,7 @@ ); --contenu-page-hauteur-minimale-avec-categories: calc( 100svh - var(--en-tete-hauteur) - var(--pied-de-page-hauteur) - - var(--menu-categories-produits-hauteur) + - var(--menu-categories-produits-hauteur) ); /* Espacements */ --espace-xs: 0.25rem; @@ -328,9 +328,6 @@ input[type=checkbox], input[type=radio] { border: 1px solid var(--couleur-noir); appearance: none; transition: 0.2s background; - /* - * 1. Pour un alignement parfait du label avec la case à cocher. - */ } input[type=checkbox]:checked, input[type=radio]:checked { background: var(--couleur-jaune); @@ -349,6 +346,11 @@ input[type=checkbox]:checked::before, input[type=radio]:checked::before { input[type=checkbox]:not(:checked):user-valid, input[type=radio]:not(:checked):user-valid { background: initial; } +input[type=checkbox], input[type=radio] { + /* + * 1. Pour un alignement parfait du label avec la case à cocher. + */ +} label:has(~ input[type=checkbox], ~ input[type=radio]), input[type=checkbox] + label, input[type=radio] + label { padding-top: 1px; /* 1 */ font-size: 0.9rem; @@ -413,13 +415,13 @@ a { transition: 0.2s background, 0.2s border-color, 0.2s color, 0.2s font-weight, 0.2s outline-color, 0.2s letter-spacing, 0.2s text-decoration-color; /* 3 */ text-decoration-skip: edges; /* 1 */ /* Change les couleurs de l'arrière-plan et du contour pour marquer le focus. */ - /* Lien ressemblant visuellement à un bouton. */ - /* Lien ressemblant à... un lien. */ - /* Styles pour les liens par défaut */ } a:focus-visible { outline-color: var(--lien-contour-couleur-focus); } +a { + /* Lien ressemblant visuellement à un bouton. */ +} a.lien-bouton { /* Marges */ --lien-bouton-marges-internes-bloc: var(--espace-xs); @@ -429,20 +431,27 @@ a.lien-bouton { padding: var(--lien-bouton-marges-internes-bloc) var(--lien-bouton-marges-internes-ligne); border: 1px solid var(--couleur-noir); /* Change la couleur de l'arrière-plan pour marquer le focus. */ - /* Change la couleur de la bordure pour qu'elle se fonde dans l'arrière-plan, donnant l'illusion que la bordure se déplace vers l'extérieur. */ - /* Change la couleur de l'arrière-plan pour marquer le survol. */ } a.lien-bouton:focus-visible { background: var(--lien-bouton-arriere-plan-couleur-survol); } +a.lien-bouton { + /* Change la couleur de la bordure pour qu'elle se fonde dans l'arrière-plan, donnant l'illusion que la bordure se déplace vers l'extérieur. */ +} a.lien-bouton:active { border-color: var(--lien-bouton-arriere-plan-couleur-survol); } +a.lien-bouton { + /* Change la couleur de l'arrière-plan pour marquer le survol. */ +} @media (hover: hover) { a.lien-bouton:hover { background: var(--lien-bouton-arriere-plan-couleur-survol); } } +a { + /* Lien ressemblant à... un lien. */ +} a.lien-lien { text-decoration: underline; } @@ -456,6 +465,9 @@ a.lien-lien:active { background: var(--couleur-jaune); } } +a { + /* Styles pour les liens par défaut */ +} @media (hover: hover) { a:not([class]):hover { text-decoration-color: var(--couleur-noir); @@ -636,7 +648,6 @@ body:has(#menu-mobile:not([aria-hidden=true])) { padding: var(--en-tete-marges-internes-bloc) var(--en-tete-marges-internes-ligne); border-bottom: 1px solid var(--couleur-noir); background: var(--couleur-gris); - /* TODO: Déplacer au sein d'un Composant ? */ } #en-tete .logo { width: var(--en-tete-logo-longueur); @@ -658,6 +669,9 @@ body:has(#menu-mobile:not([aria-hidden=true])) { align-content: center; width: 100%; } +#en-tete { + /* TODO: Déplacer au sein d'un Composant ? */ +} #en-tete .menu-navigation { display: grid; grid-template-columns: 1fr auto 1fr; @@ -665,6 +679,15 @@ body:has(#menu-mobile:not([aria-hidden=true])) { font-size: 1.1rem; text-align: center; text-transform: lowercase; +} +#en-tete .menu-navigation ul { + display: flex; + grid-column: 2; + flex-flow: row nowrap; + gap: var(--espace-m); + justify-content: space-between; +} +#en-tete .menu-navigation { /* * Le conteneur d'une entrée du menu, nécessaire pour que le changement d'arrière-plan au * survol soit possible. @@ -675,13 +698,6 @@ body:has(#menu-mobile:not([aria-hidden=true])) { * 4. Aligne le texte au centre. */ } -#en-tete .menu-navigation ul { - display: flex; - grid-column: 2; - flex-flow: row nowrap; - gap: var(--espace-m); - justify-content: space-between; -} #en-tete .menu-navigation__entree { /* Marges */ --nav-entree-marges-internes-bloc: var(--espace-xs); @@ -717,9 +733,6 @@ body:has(#menu-mobile:not([aria-hidden=true])) { gap: 1rem; place-items: center; text-align: center; - /* - * 1. Permet d'éviter un agrandissement de l'élément avec plus de 9 articles. - */ } #en-tete .compte-panier[disabled] { background: repeating-conic-gradient(var(--couleur-noir) 0% 25%, transparent 0% 100%) 1px 0.5px/2px 2px; @@ -728,6 +741,11 @@ body:has(#menu-mobile:not([aria-hidden=true])) { border: 1px solid var(--couleur-noir); background: initial; } +#en-tete .compte-panier { + /* + * 1. Permet d'éviter un agrandissement de l'élément avec plus de 9 articles. + */ +} #en-tete .compte-panier a { min-width: 10ch; /* 1 */ font-size: 1.1rem; @@ -753,13 +771,6 @@ body:has(#menu-mobile:not([aria-hidden=true])) { --menu-entree-marges-internes-ligne: var(--espace-m); position: relative; margin-top: var(--menu-section-marges-bloc-debut); /* 1 */ - /* - * Liste des Catégories de Produits. - * - * 1. Toutes les entrées font la même longueur, en respectant une contrainte de longueur - * minimale. Elles se disposent de manière à occuper tout l'espace disponible sans aller à la - * ligne. - */ } #menu-categories-produits[data-entrees-presentes-debut] svg:first-of-type { opacity: 1; @@ -789,6 +800,15 @@ body:has(#menu-mobile:not([aria-hidden=true])) { visibility: hidden; } } +#menu-categories-produits { + /* + * Liste des Catégories de Produits. + * + * 1. Toutes les entrées font la même longueur, en respectant une contrainte de longueur + * minimale. Elles se disposent de manière à occuper tout l'espace disponible sans aller à la + * ligne. + */ +} #menu-categories-produits ul { display: grid; grid-template-columns: repeat(auto-fit, minmax(var(--menu-entree-longueur-minimale), 1fr)); /* 1 */ @@ -807,11 +827,6 @@ body:has(#menu-mobile:not([aria-hidden=true])) { text-transform: uppercase; letter-spacing: var(--espacement-inter-lettres-etendu-m); background: var(--couleur-noir); - /* - * 1. Permet de créer des marges verticales. - * 2. Hérite de la longueur du conteneur. - * 3. Surchargement de styles pour les liens. - */ } #menu-categories-produits ul li.categorie-courante a { font-weight: 600; @@ -823,6 +838,13 @@ body:has(#menu-mobile:not([aria-hidden=true])) { color: var(--couleur-noir); } } +#menu-categories-produits ul li { + /* + * 1. Permet de créer des marges verticales. + * 2. Hérite de la longueur du conteneur. + * 3. Surchargement de styles pour les liens. + */ +} #menu-categories-produits ul li a { display: inline-block; /* 1 */ width: inherit; /* 2 */ @@ -1135,7 +1157,6 @@ body:has(#menu-mobile:not([aria-hidden=true])) { font-weight: var(--resume-police-selecteur-graisse); text-transform: lowercase; /* Texte du sélecteur */ - /* Conteneur des sélecteurs */ } .resume-produit .selecteur-produit__selection-variation label { margin-right: var(--espace-s); @@ -1157,6 +1178,9 @@ body:has(#menu-mobile:not([aria-hidden=true])) { .resume-produit .selecteur-produit__selection-variation option { background: var(--couleur-fond); } +.resume-produit .selecteur-produit__selection-variation { + /* Conteneur des sélecteurs */ +} .resume-produit .selecteur-produit__selection-variation__selecteurs { position: relative; /* Icône de flèche descendante */ diff --git a/web/app/themes/haiku-atelier-2024/assets/css/main.css.map b/web/app/themes/haiku-atelier-2024/assets/css/main.css.map index 383e435c..565eb980 100755 --- a/web/app/themes/haiku-atelier-2024/assets/css/main.css.map +++ b/web/app/themes/haiku-atelier-2024/assets/css/main.css.map @@ -1 +1 @@ -{"version":3,"sourceRoot":"","sources":["../../src/sass/base/polices/_lato.scss","../../src/sass/base/polices/_myriad.scss","../../src/sass/abstracts/_variables.scss","../../src/sass/base/_base.scss","../../src/sass/base/_typographie.scss","../../src/sass/base/elements/_boutons.scss","../../src/sass/base/elements/_formulaires.scss","../../src/sass/base/elements/_images.scss","../../src/sass/base/elements/_liens.scss","../../src/sass/base/elements/_listes.scss","../../src/sass/layouts/_bandeau.scss","../../src/sass/layouts/_menu-mobile.scss","../../src/sass/layouts/_en-tete.scss","../../src/sass/layouts/_menu-categories-produits.scss","../../src/sass/layouts/_colonnes-photos.scss","../../src/sass/layouts/_grille-produits.scss","../../src/sass/layouts/_informations-produit.scss","../../src/sass/layouts/_produits-similaires.scss","../../src/sass/layouts/_pied-de-page.scss"],"names":[],"mappings":";AAAA;EACE;EACA;EACA;EACA;EACA,KACE;EAQF,eACE;;AAmBJ;EACE;EACA;EACA;EACA;EACA,KACE;EAQF,eACE;;ACjDJ;EACE;EACA;EACA;EACA;EACA;EACA,KACE;;AAKJ;EACE;EACA;EACA;EACA;EACA;EACA,KACE;;ACjBJ;AACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA;AAEA;EACA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA;EACA;EAGA;EACA;AAAA;AAAA;EAGA;AAAA;AAAA;AAAA;AAKA;EACA;EACA;EACA;EACA;EACA;;;AChDF;AAAA;AAAA;AAGA;EACE;;;AAGF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;AACA;EACE;;AAGF;AAAA;AAAA;AAAA;AAIA;EACE;EACA;EACA;;;AAGF;AAAA;AAAA;AAGA;EACE;;;AAGF;AAAA;AAAA;AAGA;EACE;;;AAGF;AACA;EACE;;;AAGF;AACA;EACE;EACA;;;AAGF;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;AACA;EACE;;;AAGF;AAAA;AAAA;AAGA;EACE;IACE;IACA;IACA;;EAGF;IACE;;;AC5FJ;AAAA;AAAA;AAAA;AAIA;EACE;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;;;AAGF;AC1BA;AAAA;AAAA;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;IACE;IACA;;;AAKN;EACE;EAEA;;AAIF;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;EACA;;AAKN;EACE;EACA;;AAIA;EADF;IAEI;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGF;EACE;EACA;;AAEA;EACE;IACE;IACA;;;;AC9FV;EACE;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EAEA;;;AAKF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;;AAGF;EACE;;;AAQJ;EACE;;;AAIF;EACE;EACA;EACA;EACA;EACA;EACA;AAwBA;AAAA;AAAA;;AAtBA;EACE;;AAGA;EACE;EACA;EACA;EACA;;AAGF;EACE;IACE;;;AAKN;EACE;;AAMF;EACE;EACA;;AAGF;EACE;IACE;;;;AAKN;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAMJ;EACE;IACE;;;;AC7HN;AAAA;AAAA;AAAA;AAAA;AAKA;EACE;EACA;;;AAGF;EACE;EACA;;;ACZF;AAAA;AAAA;AAAA;AAAA;AAKA;AACE;EACA;EAEA;EACA;EACA;EACA,YACE,uIAM4B;EAE9B;AAEA;AAKA;AA8BA;AAiBA;;AAnDA;EACE;;AAIF;AACE;EACA;EACA;AAEA;EACA;EAEA;EACA;AAEA;AAKA;AAKA;;AATA;EACE;;AAIF;EACE;;AAIF;EACE;IACE;;;AAMN;EACE;;AAEA;EACE;EACA;;AAGF;EACE;IACE;IACA;;;AAOJ;EACE;IACE;;;;AC/ER;AAAA;AAAA;AAAA;AAAA;AAKA;EACE;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAMA;AACE;EACA;AAEA;EACA;AAEA;EACA;;AAEA;EACE;EACA,qLAEkE;;;AC9BxE;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAEA;EACE;;AAKN;EAEI;IACE;;;;AAMR;EACE;IACE;;EAGF;IACE;;;AC/CJ;EACE;EACA;;;AAGF;EAEE;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAEA;EACE;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAEA;EACE;EACA;EACA;;AAEA;EACE;;AAEA;EACE;EACA;;AAOV;EArEF;IAsEI;;;;AAIJ;EACE;IACE;;;AAIJ;EACE;IACE;;;AAIJ;EACE;IACE;;;AC5FJ;EAEE;EACA;EAGA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AA2BA;;AAzBA;EACE;;AAEA;EACE;;AAGF;EACE;EACA;AAEA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAKJ;EACE;EACA;EACA;EACA;EACA;EACA;AAUA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AARA;EACE;EACA;EACA;EACA;EACA;;AAYF;AACE;EACA;EACA;EACA;AAEA;EACA;;AAGA;EACE;;AAKF;EACE;;AAIF;EACE;EACA,yFAC2C;EAE3C;;AAGF;EACE;IACE;;;AAOJ;EADF;IAEI;;;AAKN;EACE;EACA;EACA;EACA;EACA;AAYA;AAAA;AAAA;;AAVA;EACE;;AAGA;EACE;EACA;;AAOJ;EACE;EACA;EACA;;AAEA;EACE;;AAGF;EACE;;;ACtJR;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA;AACE;EACA;EAGA;EACA;EAIA;EACA;AAuCA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AApCE;EACE;;AAKF;EACE;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;;AAIF;EApBF;IAqBI;;;AAWJ;EACE;EACA;EAEA;EACA;AAEA;AAAA;AAAA;;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAgBA;AAAA;AAAA;AAAA;AAAA;;AAbE;EACE;EACA;EACA;;AAEA;EACE;IACE;;;AAWR;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;IACE;IACA;;;AAMR;EA5DF;IA6DI;IAEA;IACA;IACA;;EAEA;IACE;IACA;;EAEA;IACE;IACA;;;AAMN;EA/EF;IAgFI;IACA;IACA;;EAEA;IACE;IACA;;;;ACrJR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA;EAEE;EAGA;EACA;AAAA;AAAA;EAGA;EAGA;EAEA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGA;EACE;;AAKF;EACE;EACA;;AAIF;EACE;EACA;;AAMN;EApDF;IAqDI;IACA;AAEA;IACA;IAEA;IACA;IACA;IACA;IACA;IACA;IACA;;EAEA;IACE;;EAGF;IACE;IACA;IACA;;EAEA;IACE;;EAGF;IACE;;EAGF;IACE;IACA;IACA;;EAGF;IACE;;EAEA;IACE;IACA;;EAGF;IACE;;;;AC1GV;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA;EAEE;EACA;EACA;EACA;EAEA;EACA;EACA;EAEA;EACA;;AAEA;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;;AAEA;EAEI;IACE;IACA;IACA;;;AAMR;EACE;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAIJ;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAMR;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAIJ;EACE;IACE;;EAEA;IACE;;;;AAMR;EACE;IACE;;;ACjJJ;AAAA;AAAA;AAAA;AAIA;EAEE;EAGA;EAGA;EAGA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;AAEA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;AAEA;AAyBA;;AAxBA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;IACE;;;AAKN;EACE;;AAIF;EACE;AAEA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EAEI;IACE;IACA;;;AAKN;EAEI;IACE;IACA;;;AAOV;EACE;;AAIJ;EAnIF;IAoII;IACA;;;AAGF;EAxIF;IAyII;IACA;IACA;IACA;;;AAGF;EACE;IACE;IACA;;EAEA;IACE;;;;AAMR;AAAA;AAAA;AAAA;AAIA;EACE;EACA;EACA;EACA;EACA;EAEA;;AAEA;EACE;EACA;EACA;;AAGE;EACE;;AAIF;EACE;;AAGF;EACE;;AAEA;EACE;EACA;EACA;EACA;EACA;;AAMJ;EACE;EACA;;AAEA;EACE;EACA;;AAGF;EACE;;AAGF;EACE;;AAOR;EACE;EAEA;EACA;EACA;EACA;;AAGA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAIE;EACE;IACE;;;;ACtPZ;EAEE;EACA;EACA;EAEA;EACA;EACA,qBACE;EAEF;EACA;EACA;AAEA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;;AAEA;EAEI;IACE;IACA;IACA;;;AAMR;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAMR;EACE;IACE;;EAEA;IACE;;;;ACjHV;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGA;EACE;EACA;EACA;EACA;;AAIF;EACE;EACA;EACA;EACA","file":"main.css"} \ No newline at end of file +{"version":3,"sourceRoot":"","sources":["../../src/sass/base/polices/_lato.scss","../../src/sass/base/polices/_myriad.scss","../../src/sass/abstracts/_variables.scss","../../src/sass/base/_base.scss","../../src/sass/base/_typographie.scss","../../src/sass/base/elements/_boutons.scss","../../src/sass/base/elements/_formulaires.scss","../../src/sass/base/elements/_images.scss","../../src/sass/base/elements/_liens.scss","../../src/sass/base/elements/_listes.scss","../../src/sass/layouts/_bandeau.scss","../../src/sass/layouts/_menu-mobile.scss","../../src/sass/layouts/_en-tete.scss","../../src/sass/layouts/_menu-categories-produits.scss","../../src/sass/layouts/_colonnes-photos.scss","../../src/sass/layouts/_grille-produits.scss","../../src/sass/layouts/_informations-produit.scss","../../src/sass/layouts/_produits-similaires.scss","../../src/sass/layouts/_pied-de-page.scss"],"names":[],"mappings":";AAAA;EACE;EACA;EACA;EACA;EACA,KACE;EAQF,eACE;;AAmBJ;EACE;EACA;EACA;EACA;EACA,KACE;EAQF,eACE;;ACjDJ;EACE;EACA;EACA;EACA;EACA;EACA,KACE;;AAKJ;EACE;EACA;EACA;EACA;EACA;EACA,KACE;;ACjBJ;AACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA;AAEA;EACA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA;EACA;EAGA;EACA;AAAA;AAAA;EAGA;AAAA;AAAA;AAAA;AAKA;EACA;EACA;EACA;EACA;EACA;;;AChDF;AAAA;AAAA;AAGA;EACE;;;AAGF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;AACA;EACE;;AAGF;AAAA;AAAA;AAAA;AAIA;EACE;EACA;EACA;;;AAGF;AAAA;AAAA;AAGA;EACE;;;AAGF;AAAA;AAAA;AAGA;EACE;;;AAGF;AACA;EACE;;;AAGF;AACA;EACE;EACA;;;AAGF;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;AACA;EACE;;;AAGF;AAAA;AAAA;AAGA;EACE;IACE;IACA;IACA;;EAGF;IACE;;;AC5FJ;AAAA;AAAA;AAAA;AAIA;EACE;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;;;AAGF;AC1BA;AAAA;AAAA;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;IACE;IACA;;;AAKN;EACE;EAEA;;AAIF;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;EACA;;AAKN;EACE;EACA;;AAIA;EADF;IAEI;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGF;EACE;EACA;;AAEA;EACE;IACE;IACA;;;;AC9FV;EACE;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EAEA;;;AAKF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;;AAGF;EACE;;;AAQJ;EACE;;;AAIF;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGA;EACE;EACA;EACA;EACA;;AAGF;EACE;IACE;;;AAKN;EACE;;AA3BJ;AA8BE;AAAA;AAAA;;AAGA;EACE;EACA;;AAGF;EACE;IACE;;;;AAKN;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAMJ;EACE;IACE;;;;AC7HN;AAAA;AAAA;AAAA;AAAA;AAKA;EACE;EACA;;;AAGF;EACE;EACA;;;ACZF;AAAA;AAAA;AAAA;AAAA;AAKA;AACE;EACA;EAEA;EACA;EACA;EACA,YACE,uIAM4B;EAE9B;AAEA;;AACA;EACE;;AApBJ;AAuBE;;AACA;AACE;EACA;EACA;AAEA;EACA;EAEA;EACA;AAEA;;AACA;EACE;;AAbJ;AAgBE;;AACA;EACE;;AAlBJ;AAqBE;;AACA;EACE;IACE;;;AAhDR;AAqDE;;AACA;EACE;;AAEA;EACE;EACA;;AAGF;EACE;IACE;IACA;;;AAjER;AAsEE;;AAEE;EACE;IACE;;;;AC/ER;AAAA;AAAA;AAAA;AAAA;AAKA;EACE;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAMA;AACE;EACA;AAEA;EACA;AAEA;EACA;;AAEA;EACE;EACA,qLAEkE;;;AC9BxE;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAEA;EACE;;AAKN;EAEI;IACE;;;;AAMR;EACE;IACE;;EAGF;IACE;;;AC/CJ;EACE;EACA;;;AAGF;EAEE;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAEA;EACE;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAEA;EACE;EACA;EACA;;AAEA;EACE;;AAEA;EACE;EACA;;AAOV;EArEF;IAsEI;;;;AAIJ;EACE;IACE;;;AAIJ;EACE;IACE;;;AAIJ;EACE;IACE;;;AC5FJ;EAEE;EACA;EAGA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAEA;EACE;;AAGF;EACE;EACA;AAEA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;;AA5CN;AAgDE;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;;AAbJ;AAgBE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AASA;AACE;EACA;EACA;EACA;AAEA;EACA;;AAGA;EACE;;AAKF;EACE;;AAIF;EACE;EACA,yFAC2C;EAE3C;;AAGF;EACE;IACE;;;AAOJ;EADF;IAEI;;;AAKN;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGA;EACE;EACA;;AAbN;AAiBE;AAAA;AAAA;;AAGA;EACE;EACA;EACA;;AAEA;EACE;;AAGF;EACE;;;ACtJR;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA;AACE;EACA;EAGA;EACA;EAIA;EACA;;AAGE;EACE;;AAKF;EACE;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;;AAIF;EApBF;IAqBI;;;AA9CN;AAkDE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAOA;EACE;EACA,uBACE;EAEF;EACA;AAEA;AAAA;AAAA;;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;EACA;EACA;;AAEA;EACE;IACE;;;AAlBV;AAwBE;AAAA;AAAA;AAAA;AAAA;;AAKA;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;IACE;IACA;;;AAMR;EA7DF;IA8DI;IAEA;IACA;IACA;;EAEA;IACE;IACA;;EAEA;IACE;IACA;;;AAMN;EAhFF;IAiFI;IACA;IACA;;EAEA;IACE;IACA;;;;ACtJR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA;EAEE;EAGA;EACA;AAAA;AAAA;EAGA;EAGA;EAEA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGA;EACE;;AAKF;EACE;EACA;;AAIF;EACE;EACA;;AAMN;EApDF;IAqDI;IACA;AAEA;IACA;IAEA;IACA;IACA;IACA;IACA;IACA;IACA;;EAEA;IACE;;EAGF;IACE;IACA;IACA;;EAEA;IACE;;EAGF;IACE;;EAGF;IACE;IACA;IACA;;EAGF;IACE;;EAEA;IACE;IACA;;EAGF;IACE;;;;AC1GV;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA;EAEE;EACA;EACA;EACA;EAEA;EACA;EACA,uBACE;EAEF;EACA;;AAEA;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;;AAEA;EAEI;IACE;IACA;IACA;;;AAMR;EACE;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAIJ;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAMR;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAIJ;EACE;IACE;;EAEA;IACE;;;;AAMR;EACE;IACE;;;AClJJ;AAAA;AAAA;AAAA;AAIA;EAEE;EAGA;EAGA;EAGA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;AAEA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;AAEA;;AACA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;IACE;;;AAKN;EACE;;AA3BJ;AA8BE;;AACA;EACE;AAEA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EAEI;IACE;IACA;;;AAKN;EAEI;IACE;IACA;;;AAOV;EACE;;AAIJ;EAnIF;IAoII;IACA;;;AAGF;EAxIF;IAyII;IACA;IACA;IACA;;;AAGF;EACE;IACE;IACA;;EAEA;IACE;;;;AAMR;AAAA;AAAA;AAAA;AAIA;EACE;EACA;EACA;EACA;EACA;EAEA;;AAEA;EACE;EACA;EACA;;AAGE;EACE;;AAIF;EACE;;AAGF;EACE;;AAEA;EACE;EACA;EACA;EACA;EACA;;AAMJ;EACE;EACA;;AAEA;EACE;EACA;;AAGF;EACE;;AAGF;EACE;;AAOR;EACE;EAEA;EACA;EACA;EACA;;AAGA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAIE;EACE;IACE;;;;ACtPZ;EAEE;EACA;EACA;EAEA;EACA;EACA,qBACE;EAEF;EACA;EACA;AAEA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAEA;EACE;EACA;EACA;;AAEA;EACE;;AAEA;EAEI;IACE;IACA;IACA;;;AAMR;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAMR;EACE;IACE;;EAEA;IACE;;;;ACjHV;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGA;EACE;EACA;EACA;EACA;;AAIF;EACE;EACA;EACA;EACA","file":"main.css"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css b/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css index 40268ec2..d18d7946 100755 --- a/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css +++ b/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css @@ -60,12 +60,6 @@ font-weight: 500; font-style: initial; /* Bouton d'addition de quantité */ - /* - * 1. Cache les flèches d'augmentation/diminution sur Firefox. - * 2. Cache les flèches d'augmentation/diminution sur Chrome/Edge/Safari. - */ - /* Bouton de suppression de quantité */ - /* Bouton de suppression du Produit du Panier */ } #panneau-panier .panneau__grille-produits .detail-produit__actions button:first-of-type { grid-column: 1; @@ -74,6 +68,12 @@ border: 1px solid var(--couleur-noir); border-bottom: initial; } +#panneau-panier .panneau__grille-produits .detail-produit__actions { + /* + * 1. Cache les flèches d'augmentation/diminution sur Firefox. + * 2. Cache les flèches d'augmentation/diminution sur Chrome/Edge/Safari. + */ +} #panneau-panier .panneau__grille-produits .detail-produit__actions input[type=number] { grid-column: 2; width: 100%; @@ -86,6 +86,9 @@ margin: 0; /* 2 */ appearance: none; /* 2 */ } +#panneau-panier .panneau__grille-produits .detail-produit__actions { + /* Bouton de suppression de quantité */ +} #panneau-panier .panneau__grille-produits .detail-produit__actions button:nth-of-type(2) { grid-column: 3; min-width: 3rem; @@ -93,6 +96,9 @@ border: 1px solid var(--couleur-noir); border-bottom: initial; } +#panneau-panier .panneau__grille-produits .detail-produit__actions { + /* Bouton de suppression du Produit du Panier */ +} #panneau-panier .panneau__grille-produits .detail-produit__actions button:last-of-type { grid-column: span 3; grid-row: 2; diff --git a/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css.map b/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css.map index fea2595f..3a916738 100755 --- a/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css.map +++ b/web/app/themes/haiku-atelier-2024/assets/css/pages/page-panier.css.map @@ -1 +1 @@ -{"version":3,"sourceRoot":"","sources":["../../../src/sass/layouts/_panneau-panier.scss","../../../src/sass/layouts/_panneau-informations-client.scss","../../../src/sass/pages/page-panier.scss"],"names":[],"mappings":";AAEA;EACE;;AAEA;EACE;;AAIF;EACE;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAGA;EACE;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAMN;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAIJ;EACE;EACA;;AAIF;EACE;EACA;EACA;EACA;EACA;AAEA;AASA;AAAA;AAAA;AAAA;AAkBA;AASA;;AAnCA;EACE;EACA;EACA;EACA;EACA;;AAOF;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAKJ;EACE;EACA;EACA;EACA;EACA;;AAIF;EACE;EACA;EACA;EACA;EACA;;AAOR;EACE;EACA;EACA;EACA;AAEA;AAAA;AAAA;AAAA;;AAIA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;AAEA;AAAA;AAAA;;AAGA;EACE;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAKN;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAKA;EACE;;AAEA;EACE;;AAMR;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAMJ;EACE;EACA;EACA;EACA;EACA;;AAKJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAIJ;EACE;IACE;;EAGF;IACE;;EAEA;IACE;;EAIJ;IACE;;EAGE;IACE;;EAKN;IACE;;;;ACpRN;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAIF;EAEE;EACA;EACA;EAGA;EAEA;EACA;;AAEA;EACE;EACA;;AAIF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;;AAMN;EACE;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAKF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;;AAMR;EACE;EACA;EACA;;AAIJ;EACE;EACA;;AAEA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAKN;EACE;EACA;EACA;;AAEA;EACE;;AAIJ;EACE;;AAKJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAIJ;EACE;IACE;;;;ACpKN;AAAA;AAAA;AAAA;AAIA;AACE;EACA;AAEA;EACA;EAEA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;;AAKN;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;EACA;EACA;;AAKF;EACE;;AAGF;EACE","file":"page-panier.css"} \ No newline at end of file +{"version":3,"sourceRoot":"","sources":["../../../src/sass/layouts/_panneau-panier.scss","../../../src/sass/layouts/_panneau-informations-client.scss","../../../src/sass/pages/page-panier.scss"],"names":[],"mappings":";AAEA;EACE;;AAEA;EACE;;AAIF;EACE;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAGA;EACE;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAMN;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAIJ;EACE;EACA;;AAIF;EACE;EACA;EACA;EACA;EACA;AAEA;;AACA;EACE;EACA;EACA;EACA;EACA;;AAbJ;AAgBE;AAAA;AAAA;AAAA;;AAIA;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AA9BN;AAkCE;;AACA;EACE;EACA;EACA;EACA;EACA;;AAxCJ;AA2CE;;AACA;EACE;EACA;EACA;EACA;EACA;;AAOR;EACE;EACA;EACA;EACA;AAEA;AAAA;AAAA;AAAA;;AAIA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;AAEA;AAAA;AAAA;;AAGA;EACE;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAKN;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAKA;EACE;;AAEA;EACE;;AAMR;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAMJ;EACE;EACA;EACA;EACA;EACA;;AAKJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAIJ;EACE;IACE;;EAGF;IACE;;EAEA;IACE;;EAIJ;IACE;;EAGE;IACE;;EAKN;IACE;;;;ACpRN;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAIF;EAEE;EACA;EACA;EAGA;EAEA;EACA;;AAEA;EACE;EACA;;AAIF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;;AAMN;EACE;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAKF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;;AAMR;EACE;EACA;EACA;;AAIJ;EACE;EACA;;AAEA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAKN;EACE;EACA;EACA;;AAEA;EACE;;AAIJ;EACE;;AAKJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAIJ;EACE;IACE;;;;ACpKN;AAAA;AAAA;AAAA;AAIA;AACE;EACA;AAEA;EACA;EAEA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;;AAKN;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;EACA;EACA;;AAKF;EACE;;AAGF;EACE","file":"page-panier.css"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/.vite/manifest.json b/web/app/themes/haiku-atelier-2024/assets/js/.vite/manifest.json new file mode 100644 index 00000000..0e227d2f --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/.vite/manifest.json @@ -0,0 +1,253 @@ +{ + "_api.CM5TBNEA.js": { + "file": "api.CM5TBNEA.js", + "name": "api", + "integrity": "sha512-AABJ01IYRg4AZjhIkDyxL31uCEnChGmYjKMabBBQ+kMHiF2nEjYgjQC9mtoJxTefy+pcnJLlDiOqsX9O3nYCrQ==" + }, + "_belt_Option-91f3b350.CMbgtZ-W.js": { + "file": "belt_Option-91f3b350.CMbgtZ-W.js", + "name": "belt_Option-91f3b350", + "imports": [ + "_dom.emspS_OW.js" + ], + "integrity": "sha512-iKN620+w4JvXfB55Uf+lA+8KsofasnYe3KBtVjZ2oFGk2kdDDcuV3cE7tMgYYa/EDvNWFbzr+LWVGfP1epsE5g==" + }, + "_dist.CzYTlmnN.js": { + "file": "dist.CzYTlmnN.js", + "name": "dist", + "integrity": "sha512-UdivuApdmNlhycktFxc3DyDCP87pa5BxcVji85gSzcOJTW8WuOlOplD41pBIChesnCyyRvlFB+JVljoc6B5k2A==" + }, + "_dom.emspS_OW.js": { + "file": "dom.emspS_OW.js", + "name": "dom", + "imports": [ + "_journalisation.CEgm28xa.js", + "_exports.CurVqjr0.js" + ], + "integrity": "sha512-YPKvpYsg2Tg3W7usRMln/NXOQfWvA9fOrVBQ3Jxnuxhp9MV0AKhKcqtveQeR8OvQPin5ed0cJEjlIizDoaGtVg==" + }, + "_exports.CurVqjr0.js": { + "file": "exports.CurVqjr0.js", + "name": "exports", + "integrity": "sha512-brr8BojPqo4rEpXLsE9kz3h7VtL3oZJvNi57eHT9dDBOcP0R9TSU5FQ0KgCLK77i9SsDFmqXUFkhrKLk5V8oIA==" + }, + "_gardes.CYxPzOAc.js": { + "file": "gardes.CYxPzOAc.js", + "name": "gardes", + "imports": [ + "_dom.emspS_OW.js" + ], + "integrity": "sha512-L/WrAem1zGWjXh1TbJoJRJJxAiat5UVsOaCsuSZySKtJDYHN3wW7/Gvs7AhZqT0sDfk83HM5Y0jg/xdfps31Kw==" + }, + "_index-c1cc4c86.D2nZEikK.js": { + "file": "index-c1cc4c86.D2nZEikK.js", + "name": "index-c1cc4c86", + "imports": [ + "_dom.emspS_OW.js", + "_belt_Option-91f3b350.CMbgtZ-W.js" + ], + "integrity": "sha512-q6IG0Q9RxncgYlB5W2T2DdF/p1TrX57jmznlrFxfx09vFZ1WvUqtOPdHvZDJ52ncDVsw+9xFUat5knECaKpOvg==" + }, + "_journalisation.CEgm28xa.js": { + "file": "journalisation.CEgm28xa.js", + "name": "journalisation", + "integrity": "sha512-+RQmmiXzr82fdbwmjaqSl1ByAnOFIC56vt3iKzxPWx1GDCHz3rEe/KnNzwOdQq6EIyoBNLRdEpKegxai5NGO9A==" + }, + "_messages.CqHLtCes.js": { + "file": "messages.CqHLtCes.js", + "name": "messages", + "imports": [ + "_dom.emspS_OW.js", + "_exports.CurVqjr0.js", + "_validation.CYJDC5vQ.js" + ], + "integrity": "sha512-PSSJZ1ojYBnJ0OK5v6bwKRuoahZfpXiVeY7nX/HI7Umirp8PCJBjeGINwQmMxcwwqz6OKiXldoL2qfcRcNd/6Q==" + }, + "_nombres.E65h3XxA.js": { + "file": "nombres.E65h3XxA.js", + "name": "nombres", + "imports": [ + "_exports.CurVqjr0.js" + ], + "integrity": "sha512-rl6R7Csed4t+dce6c/Vu+S5Rb7msei7ftl6qWJc8azZ0jKuYI3OXlR/MVnJfXzG+HbcfUZbZDaNv1OJOveVNfQ==" + }, + "_reseau.BY4MrTI9.js": { + "file": "reseau.BY4MrTI9.js", + "name": "reseau", + "imports": [ + "_dom.emspS_OW.js", + "_dist.CzYTlmnN.js", + "_api.CM5TBNEA.js" + ], + "integrity": "sha512-AYhe2dWN1+DAyybERSUMDbNxZWSKGPZdbJSL62WUqh7tqQkIBSxqz9eCZaxpQmEgEnQStEP42rs5Lnw5B34KqA==" + }, + "_validation.CYJDC5vQ.js": { + "file": "validation.CYJDC5vQ.js", + "name": "validation", + "imports": [ + "_dom.emspS_OW.js" + ], + "integrity": "sha512-l+91IOv2M5mEMn8J9n1lTYPSV6vG++44Bq9o67eUVvpdjS5vT3QzVWqJCwKu+VuUStJ7SqYKltHUE48v+2QDng==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/gaffe.ts": { + "file": "gaffe.js", + "name": "gaffe", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/gaffe.ts", + "isEntry": true, + "imports": [ + "_exports.CurVqjr0.js", + "_api.CM5TBNEA.js" + ], + "integrity": "sha512-wK/GuqvTHTnA3qIlWYM+kOyxbtnmDhrc1Zbm2Q2A/Ys/Ia0RZjRn0zOnfZyBZ4ZUUCxIqXujDMuSGAxt9vefXA==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/journalisation.ts": { + "file": "journalisation.js", + "name": "journalisation", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/journalisation.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js" + ], + "integrity": "sha512-xf2CXCF82ZOHVw0v3Dqn1xt+Ow+hURD5GbYxt3L/4LH9Nk2Bmw6oOkZc8+tErRDMMDTEt1KXPHC2kN0MxYptNw==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-bouton-panier.ts": { + "file": "scripts-bouton-panier.js", + "name": "scripts-bouton-panier", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-bouton-panier.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_exports.CurVqjr0.js", + "_messages.CqHLtCes.js", + "_validation.CYJDC5vQ.js" + ], + "integrity": "sha512-ckqj4fSd9bihiTUPHqXwL5Y6iBxGsKNKc9EO4iQdcmAubh4ZuBxAyJmdMP3eipRUWTMXW8J4g6wZwgWfbccs1A==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-bouton-retour-sommet.ts": { + "file": "scripts-bouton-retour-sommet.js", + "name": "scripts-bouton-retour-sommet", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-bouton-retour-sommet.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_index-c1cc4c86.D2nZEikK.js", + "_belt_Option-91f3b350.CMbgtZ-W.js", + "_exports.CurVqjr0.js" + ], + "integrity": "sha512-uPmbT4qZhDzWned/hCwIkD+9w9YqI9DxEMZPTRIRUktCwP0AFN/PQdoeXt7Y+bx3uQHQJfqandH8K1KsJFTWyA==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-menu-categories.ts": { + "file": "scripts-menu-categories.js", + "name": "scripts-menu-categories", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-menu-categories.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_exports.CurVqjr0.js", + "_dist.CzYTlmnN.js" + ], + "integrity": "sha512-FYD3NzdZotGpgZubWx9hoSsB75nZakLjdebgZqEzBg16P2FqQ9UfF579Xgy9JHfAkeBEhn17u47SgPZi8yuHcQ==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-menu-mobile.ts": { + "file": "scripts-menu-mobile.js", + "name": "scripts-menu-mobile", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-menu-mobile.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_index-c1cc4c86.D2nZEikK.js", + "_belt_Option-91f3b350.CMbgtZ-W.js", + "_exports.CurVqjr0.js" + ], + "integrity": "sha512-hwMyxnBDsfYX9u/AvP54qfo9RDoke50/XZXwTaO6UXGcbVBxzYecfi7pJ1MK0CPvOthKiyeOiDUL+af+tI4ybw==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-a-propos.ts": { + "file": "scripts-page-a-propos.js", + "name": "scripts-page-a-propos", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-a-propos.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_index-c1cc4c86.D2nZEikK.js", + "_belt_Option-91f3b350.CMbgtZ-W.js", + "_exports.CurVqjr0.js" + ], + "integrity": "sha512-pmpSmvayHr4srvO5UZz5xFzJYwgt46ezELw+D0uE/uVo2vZ9J3iVa3F9WInj9jR66vbzeXXNYP4JV8p7JoF6hQ==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-accueil.ts": { + "file": "scripts-page-accueil.js", + "name": "scripts-page-accueil", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-accueil.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_index-c1cc4c86.D2nZEikK.js", + "_belt_Option-91f3b350.CMbgtZ-W.js", + "_nombres.E65h3XxA.js", + "_exports.CurVqjr0.js" + ], + "integrity": "sha512-P7UQifPtkEOx075C6/TmYgm9wAD1W3v3N8LbN2Rh5PSv+SRRnt1spJuxVnAd2hHBLl607R+ukgPVaJzAU/FwUw==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-boutique.ts": { + "file": "scripts-page-boutique.js", + "name": "scripts-page-boutique", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-boutique.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_belt_Option-91f3b350.CMbgtZ-W.js", + "_exports.CurVqjr0.js", + "_reseau.BY4MrTI9.js", + "_dist.CzYTlmnN.js", + "_api.CM5TBNEA.js", + "_validation.CYJDC5vQ.js" + ], + "integrity": "sha512-DR6V+H2sb989gH5GMa3XG1cinptEGFrd+DVPIW3bhucAWelpWN89oznv17kpJl4mybwNN41AxRe3n/YaYF6hDw==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-panier.ts": { + "file": "scripts-page-panier.js", + "name": "scripts-page-panier", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-panier.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_nombres.E65h3XxA.js", + "_gardes.CYxPzOAc.js", + "_exports.CurVqjr0.js", + "_reseau.BY4MrTI9.js", + "_dist.CzYTlmnN.js", + "_api.CM5TBNEA.js", + "_messages.CqHLtCes.js", + "_validation.CYJDC5vQ.js" + ], + "integrity": "sha512-sxZ6sUCls7YH1Ay28qAGplVoKPZXizkBmftXWUZRDQM0QZkHul+z0r7LQZEj80cypv4y41DBjHcYL0FtmQ126A==" + }, + "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-produit.ts": { + "file": "scripts-page-produit.js", + "name": "scripts-page-produit", + "src": "web/app/themes/haiku-atelier-2024/src/scripts/scripts-page-produit.ts", + "isEntry": true, + "imports": [ + "_journalisation.CEgm28xa.js", + "_dom.emspS_OW.js", + "_index-c1cc4c86.D2nZEikK.js", + "_belt_Option-91f3b350.CMbgtZ-W.js", + "_gardes.CYxPzOAc.js", + "_exports.CurVqjr0.js", + "_reseau.BY4MrTI9.js", + "_dist.CzYTlmnN.js", + "_api.CM5TBNEA.js", + "_messages.CqHLtCes.js", + "_validation.CYJDC5vQ.js" + ], + "integrity": "sha512-HPTb17x7W8u8itHBCC2A7M0Y8bjzpP+WSCKjyg1daBtcovdGfR1AXwl62DxKvqxDHD3/zNM3dPDbbOoCTF8tlg==" + } +} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js b/web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js new file mode 100644 index 00000000..df90921e --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js @@ -0,0 +1,21 @@ +//#region web/app/themes/haiku-atelier-2024/src/scripts/constantes/api.ts +/** Chemins et Routes pour l'API WordPress/ */ +const CHEMIN_API_REST = "wp-json"; +const ROUTE_API_AJOUTE_ARTICLE_PANIER = `/${CHEMIN_API_REST}/wc/store/cart/add-item`; +const ROUTE_API_APPLIQUE_COUPON = `/${CHEMIN_API_REST}/wc/store/cart/apply-coupon`; +const ROUTE_API_COUPONS = `/${CHEMIN_API_REST}/wc/store/cart/coupons`; +const ROUTE_API_MAJ_ARTICLE_PANIER = `/${CHEMIN_API_REST}/wc/store/cart/update-item`; +const ROUTE_API_MAJ_CLIENT = `/${CHEMIN_API_REST}/wc/store/cart/update-customer`; +const ROUTE_API_NOUVELLE_COMMANDES = `/${CHEMIN_API_REST}/wc/v3/orders`; +const ROUTE_API_NOUVELLE_PRODUCTS = `/${CHEMIN_API_REST}/wc/v3/products`; +const ROUTE_API_PANIER = `/${CHEMIN_API_REST}/wc/store/cart`; +const ROUTE_API_PRODUITS = `/${CHEMIN_API_REST}/wc/store/products`; +const ROUTE_API_RETIRE_ARTICLE_PANIER = `/${CHEMIN_API_REST}/wc/store/cart/remove-item`; +const ROUTE_API_RETIRE_COUPON = `/${CHEMIN_API_REST}/wc/store/cart/remove-coupon`; +const ENTETE_WC_NONCE = "Nonce"; +const ENTETE_GLITCHTIP_RETRY_AFTER = "retry-after"; +const ENTETE_GLITCHTIP_RATE_LIMITS = "x-sentry-rate-limits"; + +//#endregion +export { ROUTE_API_APPLIQUE_COUPON as a, ROUTE_API_NOUVELLE_COMMANDES as c, ROUTE_API_RETIRE_COUPON as d, ROUTE_API_AJOUTE_ARTICLE_PANIER as i, ROUTE_API_NOUVELLE_PRODUCTS as l, ENTETE_GLITCHTIP_RETRY_AFTER as n, ROUTE_API_MAJ_ARTICLE_PANIER as o, ENTETE_WC_NONCE as r, ROUTE_API_MAJ_CLIENT as s, ENTETE_GLITCHTIP_RATE_LIMITS as t, ROUTE_API_RETIRE_ARTICLE_PANIER as u }; +//# sourceMappingURL=api.CM5TBNEA.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js.map b/web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js.map new file mode 100644 index 00000000..e0c06fa1 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/api.CM5TBNEA.js.map @@ -0,0 +1 @@ +{"version":3,"file":"api.CM5TBNEA.js","names":[],"sources":["../../src/scripts/constantes/api.ts"],"sourcesContent":["/** Chemins et Routes pour l'API WordPress/ */\n\nexport const CHEMIN_API_REST = \"wp-json\";\nexport const ROUTE_API_AJOUTE_ARTICLE_PANIER = `/${CHEMIN_API_REST}/wc/store/cart/add-item`;\nexport const ROUTE_API_APPLIQUE_COUPON = `/${CHEMIN_API_REST}/wc/store/cart/apply-coupon`;\nexport const ROUTE_API_COUPONS = `/${CHEMIN_API_REST}/wc/store/cart/coupons`;\nexport const ROUTE_API_MAJ_ARTICLE_PANIER = `/${CHEMIN_API_REST}/wc/store/cart/update-item`;\nexport const ROUTE_API_MAJ_CLIENT = `/${CHEMIN_API_REST}/wc/store/cart/update-customer`;\nexport const ROUTE_API_NOUVELLE_COMMANDES = `/${CHEMIN_API_REST}/wc/v3/orders`;\nexport const ROUTE_API_NOUVELLE_PRODUCTS = `/${CHEMIN_API_REST}/wc/v3/products`;\nexport const ROUTE_API_PANIER = `/${CHEMIN_API_REST}/wc/store/cart`;\nexport const ROUTE_API_PRODUITS = `/${CHEMIN_API_REST}/wc/store/products`;\nexport const ROUTE_API_RETIRE_ARTICLE_PANIER = `/${CHEMIN_API_REST}/wc/store/cart/remove-item`;\nexport const ROUTE_API_RETIRE_COUPON = `/${CHEMIN_API_REST}/wc/store/cart/remove-coupon`;\n\n// En-têtes\nexport const ENTETE_WC_NONCE = \"Nonce\";\nexport const ENTETE_GLITCHTIP_RETRY_AFTER = \"retry-after\";\nexport const ENTETE_GLITCHTIP_RATE_LIMITS = \"x-sentry-rate-limits\";\n"],"mappings":";;AAEA,MAAa,kBAAkB;AAC/B,MAAa,kCAAkC,IAAI,gBAAgB;AACnE,MAAa,4BAA4B,IAAI,gBAAgB;AAC7D,MAAa,oBAAoB,IAAI,gBAAgB;AACrD,MAAa,+BAA+B,IAAI,gBAAgB;AAChE,MAAa,uBAAuB,IAAI,gBAAgB;AACxD,MAAa,+BAA+B,IAAI,gBAAgB;AAChE,MAAa,8BAA8B,IAAI,gBAAgB;AAC/D,MAAa,mBAAmB,IAAI,gBAAgB;AACpD,MAAa,qBAAqB,IAAI,gBAAgB;AACtD,MAAa,kCAAkC,IAAI,gBAAgB;AACnE,MAAa,0BAA0B,IAAI,gBAAgB;AAG3D,MAAa,kBAAkB;AAC/B,MAAa,+BAA+B;AAC5C,MAAa,+BAA+B"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js b/web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js new file mode 100644 index 00000000..77043d77 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js @@ -0,0 +1,109 @@ +import { Dn as valFromOption, En as some } from "./dom.emspS_OW.js"; + +//#region node_modules/@mobily/ts-belt/dist/caml_exceptions-99f2c2ac.mjs +function sub(n$1, r, t) { + var e = new Array(t); + var u = 0; + var a = r; + while (u < t) { + e[u] = n$1[a]; + u = u + 1 | 0; + a = a + 1 | 0; + } + return e; +} +function app(n$1, r) { + while (1) { + var t = r; + var e = n$1; + var u = e.length; + var a = 0 === u ? 1 : u; + var c = a - t.length | 0; + if (0 === c) return e.apply(null, t); + if (c >= 0) return function(n$2, r$1) { + return function(t$1) { + return app(n$2, r$1.concat([t$1])); + }; + }(e, t); + r = sub(t, a, 0 | -c); + n$1 = e.apply(null, sub(t, 0, a)); + } +} +function _1(n$1, r) { + var t = n$1.length; + if (1 === t) return n$1(r); + else switch (t) { + case 1: return n$1(r); + case 2: return function(t$1) { + return n$1(r, t$1); + }; + case 3: return function(t$1, e) { + return n$1(r, t$1, e); + }; + case 4: return function(t$1, e, u) { + return n$1(r, t$1, e, u); + }; + case 5: return function(t$1, e, u, a) { + return n$1(r, t$1, e, u, a); + }; + case 6: return function(t$1, e, u, a, c) { + return n$1(r, t$1, e, u, a, c); + }; + case 7: return function(t$1, e, u, a, c, i) { + return n$1(r, t$1, e, u, a, c, i); + }; + default: return app(n$1, [r]); + } +} +function __1(n$1) { + if (1 === n$1.length) return n$1; + else return function(r) { + return _1(n$1, r); + }; +} +var n = { contents: 0 }; +function create(r) { + n.contents = n.contents + 1 | 0; + return r + "/" + n.contents; +} +function is_extension(n$1) { + if (null == n$1) return !1; + else return "string" == typeof n$1.RE_EXN_ID; +} + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/belt_Option-91f3b350.mjs +function getExn(t) { + if (void 0 !== t) return valFromOption(t); + throw { + RE_EXN_ID: "Not_found", + Error: /* @__PURE__ */ new Error() + }; +} +function mapWithDefaultU(t, i, a) { + if (void 0 !== t) return a(valFromOption(t)); + else return i; +} +function mapU(t, a) { + if (void 0 !== t) return some(a(valFromOption(t))); +} +function flatMapU(t, i) { + if (void 0 !== t) return i(valFromOption(t)); +} +function flatMap(n$1, i) { + return flatMapU(n$1, __1(i)); +} +function getWithDefault(t, i) { + if (void 0 !== t) return valFromOption(t); + else return i; +} +function isSome(t) { + return void 0 !== t; +} +function isNone(t) { + return void 0 === t; +} + +//#endregion +export { isNone as a, mapWithDefaultU as c, is_extension as d, getWithDefault as i, _1 as l, flatMapU as n, isSome as o, getExn as r, mapU as s, flatMap as t, create as u }; +//# sourceMappingURL=belt_Option-91f3b350.CMbgtZ-W.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js.map b/web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js.map new file mode 100644 index 00000000..7150defb --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/belt_Option-91f3b350.CMbgtZ-W.js.map @@ -0,0 +1 @@ +{"version":3,"file":"belt_Option-91f3b350.CMbgtZ-W.js","names":["n","r","t","n","i","t"],"sources":["../../../../../../node_modules/@mobily/ts-belt/dist/caml_exceptions-99f2c2ac.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/belt_Option-91f3b350.mjs"],"sourcesContent":["function sub(n, r, t) {\n var e = new Array(t);\n var u = 0;\n var a = r;\n while (u < t) {\n e[u] = n[a];\n u = u + 1 | 0;\n a = a + 1 | 0;\n }\n return e;\n}\n\nfunction app(n, r) {\n while (1) {\n var t = r;\n var e = n;\n var u = e.length;\n var a = 0 === u ? 1 : u;\n var c = a - t.length | 0;\n if (0 === c) {\n return e.apply(null, t);\n }\n if (c >= 0) {\n return function(n, r) {\n return function(t) {\n return app(n, r.concat([ t ]));\n };\n }(e, t);\n }\n r = sub(t, a, 0 | -c);\n n = e.apply(null, sub(t, 0, a));\n }\n}\n\nfunction _1(n, r) {\n var t = n.length;\n if (1 === t) {\n return n(r);\n } else {\n switch (t) {\n case 1:\n return n(r);\n\n case 2:\n return function(t) {\n return n(r, t);\n };\n\n case 3:\n return function(t, e) {\n return n(r, t, e);\n };\n\n case 4:\n return function(t, e, u) {\n return n(r, t, e, u);\n };\n\n case 5:\n return function(t, e, u, a) {\n return n(r, t, e, u, a);\n };\n\n case 6:\n return function(t, e, u, a, c) {\n return n(r, t, e, u, a, c);\n };\n\n case 7:\n return function(t, e, u, a, c, i) {\n return n(r, t, e, u, a, c, i);\n };\n\n default:\n return app(n, [ r ]);\n }\n }\n}\n\nfunction __1(n) {\n if (1 === n.length) {\n return n;\n } else {\n return function(r) {\n return _1(n, r);\n };\n }\n}\n\nvar n = {\n contents: 0\n};\n\nfunction create(r) {\n n.contents = n.contents + 1 | 0;\n return r + \"/\" + n.contents;\n}\n\nfunction is_extension(n) {\n if (null == n) {\n return !1;\n } else {\n return \"string\" == typeof n.RE_EXN_ID;\n }\n}\n\nexport { __1 as _, _1 as a, create as c, is_extension as i };\n","import { _ as t } from \"./caml_exceptions-99f2c2ac.mjs\";\n\nimport { v as n, s as i } from \"./caml_option-16487d6d.mjs\";\n\nfunction getExn(t) {\n if (void 0 !== t) {\n return n(t);\n }\n throw {\n RE_EXN_ID: \"Not_found\",\n Error: new Error\n };\n}\n\nfunction mapWithDefaultU(t, i, a) {\n if (void 0 !== t) {\n return a(n(t));\n } else {\n return i;\n }\n}\n\nfunction mapU(t, a) {\n if (void 0 !== t) {\n return i(a(n(t)));\n }\n}\n\nfunction flatMapU(t, i) {\n if (void 0 !== t) {\n return i(n(t));\n }\n}\n\nfunction flatMap(n, i) {\n return flatMapU(n, t(i));\n}\n\nfunction getWithDefault(t, i) {\n if (void 0 !== t) {\n return n(t);\n } else {\n return i;\n }\n}\n\nfunction isSome(t) {\n return void 0 !== t;\n}\n\nfunction isNone(t) {\n return void 0 === t;\n}\n\nexport { getWithDefault as a, isNone as b, mapU as c, flatMapU as d, flatMap as f, getExn as g, isSome as i, mapWithDefaultU as m };\n"],"x_google_ignoreList":[0,1],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js b/web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js new file mode 100644 index 00000000..39d220ec --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js @@ -0,0 +1,405 @@ +//#region node_modules/ts-pattern/dist/index.js +var t = Symbol.for("@ts-pattern/matcher"), e = Symbol.for("@ts-pattern/isVariadic"), n = "@ts-pattern/anonymous-select-key", r = (t$1) => Boolean(t$1 && "object" == typeof t$1), i = (e$1) => e$1 && !!e$1[t], o = (n$1, s$1, c$1) => { + if (i(n$1)) { + const { matched: r$1, selections: i$1 } = n$1[t]().match(s$1); + return r$1 && i$1 && Object.keys(i$1).forEach((t$1) => c$1(t$1, i$1[t$1])), r$1; + } + if (r(n$1)) { + if (!r(s$1)) return !1; + if (Array.isArray(n$1)) { + if (!Array.isArray(s$1)) return !1; + let t$1 = [], r$1 = [], u$1 = []; + for (const o$1 of n$1.keys()) { + const s$2 = n$1[o$1]; + i(s$2) && s$2[e] ? u$1.push(s$2) : u$1.length ? r$1.push(s$2) : t$1.push(s$2); + } + if (u$1.length) { + if (u$1.length > 1) throw new Error("Pattern error: Using `...P.array(...)` several times in a single pattern is not allowed."); + if (s$1.length < t$1.length + r$1.length) return !1; + const e$1 = s$1.slice(0, t$1.length), n$2 = 0 === r$1.length ? [] : s$1.slice(-r$1.length), i$1 = s$1.slice(t$1.length, 0 === r$1.length ? Infinity : -r$1.length); + return t$1.every((t$2, n$3) => o(t$2, e$1[n$3], c$1)) && r$1.every((t$2, e$2) => o(t$2, n$2[e$2], c$1)) && (0 === u$1.length || o(u$1[0], i$1, c$1)); + } + return n$1.length === s$1.length && n$1.every((t$2, e$1) => o(t$2, s$1[e$1], c$1)); + } + return Reflect.ownKeys(n$1).every((e$1) => { + const r$1 = n$1[e$1]; + return (e$1 in s$1 || i(u$1 = r$1) && "optional" === u$1[t]().matcherType) && o(r$1, s$1[e$1], c$1); + var u$1; + }); + } + return Object.is(s$1, n$1); +}, s = (e$1) => { + var n$1, o$1, u$1; + return r(e$1) ? i(e$1) ? null != (n$1 = null == (o$1 = (u$1 = e$1[t]()).getSelectionKeys) ? void 0 : o$1.call(u$1)) ? n$1 : [] : Array.isArray(e$1) ? c(e$1, s) : c(Object.values(e$1), s) : []; +}, c = (t$1, e$1) => t$1.reduce((t$2, n$1) => t$2.concat(e$1(n$1)), []); +function u(...t$1) { + if (1 === t$1.length) { + const [e$1] = t$1; + return (t$2) => o(e$1, t$2, () => {}); + } + if (2 === t$1.length) { + const [e$1, n$1] = t$1; + return o(e$1, n$1, () => {}); + } + throw new Error(`isMatching wasn't given the right number of arguments: expected 1 or 2, received ${t$1.length}.`); +} +function a(t$1) { + return Object.assign(t$1, { + optional: () => h(t$1), + and: (e$1) => d(t$1, e$1), + or: (e$1) => y(t$1, e$1), + select: (e$1) => void 0 === e$1 ? v(t$1) : v(e$1, t$1) + }); +} +function l(t$1) { + return Object.assign(((t$2) => Object.assign(t$2, { [Symbol.iterator]() { + let n$1 = 0; + const r$1 = [{ + value: Object.assign(t$2, { [e]: !0 }), + done: !1 + }, { + done: !0, + value: void 0 + }]; + return { next: () => { + var t$3; + return null != (t$3 = r$1[n$1++]) ? t$3 : r$1.at(-1); + } }; + } }))(t$1), { + optional: () => l(h(t$1)), + select: (e$1) => l(void 0 === e$1 ? v(t$1) : v(e$1, t$1)) + }); +} +function h(e$1) { + return a({ [t]: () => ({ + match: (t$1) => { + let n$1 = {}; + const r$1 = (t$2, e$2) => { + n$1[t$2] = e$2; + }; + return void 0 === t$1 ? (s(e$1).forEach((t$2) => r$1(t$2, void 0)), { + matched: !0, + selections: n$1 + }) : { + matched: o(e$1, t$1, r$1), + selections: n$1 + }; + }, + getSelectionKeys: () => s(e$1), + matcherType: "optional" + }) }); +} +var f = (t$1, e$1) => { + for (const n$1 of t$1) if (!e$1(n$1)) return !1; + return !0; +}, g = (t$1, e$1) => { + for (const [n$1, r$1] of t$1.entries()) if (!e$1(r$1, n$1)) return !1; + return !0; +}, m = (t$1, e$1) => { + const n$1 = Reflect.ownKeys(t$1); + for (const r$1 of n$1) if (!e$1(r$1, t$1[r$1])) return !1; + return !0; +}; +function d(...e$1) { + return a({ [t]: () => ({ + match: (t$1) => { + let n$1 = {}; + const r$1 = (t$2, e$2) => { + n$1[t$2] = e$2; + }; + return { + matched: e$1.every((e$2) => o(e$2, t$1, r$1)), + selections: n$1 + }; + }, + getSelectionKeys: () => c(e$1, s), + matcherType: "and" + }) }); +} +function y(...e$1) { + return a({ [t]: () => ({ + match: (t$1) => { + let n$1 = {}; + const r$1 = (t$2, e$2) => { + n$1[t$2] = e$2; + }; + return c(e$1, s).forEach((t$2) => r$1(t$2, void 0)), { + matched: e$1.some((e$2) => o(e$2, t$1, r$1)), + selections: n$1 + }; + }, + getSelectionKeys: () => c(e$1, s), + matcherType: "or" + }) }); +} +function p(e$1) { + return { [t]: () => ({ match: (t$1) => ({ matched: Boolean(e$1(t$1)) }) }) }; +} +function v(...e$1) { + const r$1 = "string" == typeof e$1[0] ? e$1[0] : void 0, i$1 = 2 === e$1.length ? e$1[1] : "string" == typeof e$1[0] ? void 0 : e$1[0]; + return a({ [t]: () => ({ + match: (t$1) => { + let e$2 = { [null != r$1 ? r$1 : n]: t$1 }; + return { + matched: void 0 === i$1 || o(i$1, t$1, (t$2, n$1) => { + e$2[t$2] = n$1; + }), + selections: e$2 + }; + }, + getSelectionKeys: () => [null != r$1 ? r$1 : n].concat(void 0 === i$1 ? [] : s(i$1)) + }) }); +} +function b(t$1) { + return !0; +} +function w(t$1) { + return "number" == typeof t$1; +} +function S(t$1) { + return "string" == typeof t$1; +} +function j(t$1) { + return "bigint" == typeof t$1; +} +var K = a(p(b)), O = a(p(b)), E = K, x = (t$1) => Object.assign(a(t$1), { + startsWith: (e$1) => { + return x(d(t$1, (n$1 = e$1, p((t$2) => S(t$2) && t$2.startsWith(n$1))))); + var n$1; + }, + endsWith: (e$1) => { + return x(d(t$1, (n$1 = e$1, p((t$2) => S(t$2) && t$2.endsWith(n$1))))); + var n$1; + }, + minLength: (e$1) => x(d(t$1, ((t$2) => p((e$2) => S(e$2) && e$2.length >= t$2))(e$1))), + length: (e$1) => x(d(t$1, ((t$2) => p((e$2) => S(e$2) && e$2.length === t$2))(e$1))), + maxLength: (e$1) => x(d(t$1, ((t$2) => p((e$2) => S(e$2) && e$2.length <= t$2))(e$1))), + includes: (e$1) => { + return x(d(t$1, (n$1 = e$1, p((t$2) => S(t$2) && t$2.includes(n$1))))); + var n$1; + }, + regex: (e$1) => { + return x(d(t$1, (n$1 = e$1, p((t$2) => S(t$2) && Boolean(t$2.match(n$1)))))); + var n$1; + } +}), A = x(p(S)), N = (t$1) => Object.assign(a(t$1), { + between: (e$1, n$1) => N(d(t$1, ((t$2, e$2) => p((n$2) => w(n$2) && t$2 <= n$2 && e$2 >= n$2))(e$1, n$1))), + lt: (e$1) => N(d(t$1, ((t$2) => p((e$2) => w(e$2) && e$2 < t$2))(e$1))), + gt: (e$1) => N(d(t$1, ((t$2) => p((e$2) => w(e$2) && e$2 > t$2))(e$1))), + lte: (e$1) => N(d(t$1, ((t$2) => p((e$2) => w(e$2) && e$2 <= t$2))(e$1))), + gte: (e$1) => N(d(t$1, ((t$2) => p((e$2) => w(e$2) && e$2 >= t$2))(e$1))), + int: () => N(d(t$1, p((t$2) => w(t$2) && Number.isInteger(t$2)))), + finite: () => N(d(t$1, p((t$2) => w(t$2) && Number.isFinite(t$2)))), + positive: () => N(d(t$1, p((t$2) => w(t$2) && t$2 > 0))), + negative: () => N(d(t$1, p((t$2) => w(t$2) && t$2 < 0))) +}), P = N(p(w)), k = (t$1) => Object.assign(a(t$1), { + between: (e$1, n$1) => k(d(t$1, ((t$2, e$2) => p((n$2) => j(n$2) && t$2 <= n$2 && e$2 >= n$2))(e$1, n$1))), + lt: (e$1) => k(d(t$1, ((t$2) => p((e$2) => j(e$2) && e$2 < t$2))(e$1))), + gt: (e$1) => k(d(t$1, ((t$2) => p((e$2) => j(e$2) && e$2 > t$2))(e$1))), + lte: (e$1) => k(d(t$1, ((t$2) => p((e$2) => j(e$2) && e$2 <= t$2))(e$1))), + gte: (e$1) => k(d(t$1, ((t$2) => p((e$2) => j(e$2) && e$2 >= t$2))(e$1))), + positive: () => k(d(t$1, p((t$2) => j(t$2) && t$2 > 0))), + negative: () => k(d(t$1, p((t$2) => j(t$2) && t$2 < 0))) +}); +var z = { + __proto__: null, + matcher: t, + optional: h, + array: function(...e$1) { + return l({ [t]: () => ({ + match: (t$1) => { + if (!Array.isArray(t$1)) return { matched: !1 }; + if (0 === e$1.length) return { matched: !0 }; + const n$1 = e$1[0]; + let r$1 = {}; + if (0 === t$1.length) return s(n$1).forEach((t$2) => { + r$1[t$2] = []; + }), { + matched: !0, + selections: r$1 + }; + const i$1 = (t$2, e$2) => { + r$1[t$2] = (r$1[t$2] || []).concat([e$2]); + }; + return { + matched: t$1.every((t$2) => o(n$1, t$2, i$1)), + selections: r$1 + }; + }, + getSelectionKeys: () => 0 === e$1.length ? [] : s(e$1[0]) + }) }); + }, + set: function(...e$1) { + return a({ [t]: () => ({ + match: (t$1) => { + if (!(t$1 instanceof Set)) return { matched: !1 }; + let n$1 = {}; + if (0 === t$1.size) return { + matched: !0, + selections: n$1 + }; + if (0 === e$1.length) return { matched: !0 }; + const r$1 = (t$2, e$2) => { + n$1[t$2] = (n$1[t$2] || []).concat([e$2]); + }, i$1 = e$1[0]; + return { + matched: f(t$1, (t$2) => o(i$1, t$2, r$1)), + selections: n$1 + }; + }, + getSelectionKeys: () => 0 === e$1.length ? [] : s(e$1[0]) + }) }); + }, + map: function(...e$1) { + return a({ [t]: () => ({ + match: (t$1) => { + if (!(t$1 instanceof Map)) return { matched: !1 }; + let n$1 = {}; + if (0 === t$1.size) return { + matched: !0, + selections: n$1 + }; + const r$1 = (t$2, e$2) => { + n$1[t$2] = (n$1[t$2] || []).concat([e$2]); + }; + if (0 === e$1.length) return { matched: !0 }; + var i$1; + if (1 === e$1.length) throw new Error(`\`P.map\` wasn't given enough arguments. Expected (key, value), received ${null == (i$1 = e$1[0]) ? void 0 : i$1.toString()}`); + const [s$1, c$1] = e$1; + return { + matched: g(t$1, (t$2, e$2) => { + const n$2 = o(s$1, e$2, r$1), i$2 = o(c$1, t$2, r$1); + return n$2 && i$2; + }), + selections: n$1 + }; + }, + getSelectionKeys: () => 0 === e$1.length ? [] : [...s(e$1[0]), ...s(e$1[1])] + }) }); + }, + record: function(...e$1) { + return a({ [t]: () => ({ + match: (t$1) => { + if (null === t$1 || "object" != typeof t$1 || Array.isArray(t$1)) return { matched: !1 }; + var n$1; + if (0 === e$1.length) throw new Error(`\`P.record\` wasn't given enough arguments. Expected (value) or (key, value), received ${null == (n$1 = e$1[0]) ? void 0 : n$1.toString()}`); + let r$1 = {}; + const i$1 = (t$2, e$2) => { + r$1[t$2] = (r$1[t$2] || []).concat([e$2]); + }, [s$1, c$1] = 1 === e$1.length ? [A, e$1[0]] : e$1; + return { + matched: m(t$1, (t$2, e$2) => { + const n$2 = "string" != typeof t$2 || Number.isNaN(Number(t$2)) ? null : Number(t$2), r$2 = null !== n$2 && o(s$1, n$2, i$1), u$1 = o(s$1, t$2, i$1), a$1 = o(c$1, e$2, i$1); + return (u$1 || r$2) && a$1; + }), + selections: r$1 + }; + }, + getSelectionKeys: () => 0 === e$1.length ? [] : [...s(e$1[0]), ...s(e$1[1])] + }) }); + }, + intersection: d, + union: y, + not: function(e$1) { + return a({ [t]: () => ({ + match: (t$1) => ({ matched: !o(e$1, t$1, () => {}) }), + getSelectionKeys: () => [], + matcherType: "not" + }) }); + }, + when: p, + select: v, + any: K, + unknown: O, + _: E, + string: A, + number: P, + bigint: k(p(j)), + boolean: a(p(function(t$1) { + return "boolean" == typeof t$1; + })), + symbol: a(p(function(t$1) { + return "symbol" == typeof t$1; + })), + nullish: a(p(function(t$1) { + return null == t$1; + })), + nonNullable: a(p(function(t$1) { + return null != t$1; + })), + instanceOf: function(t$1) { + return a(p(function(t$2) { + return (e$1) => e$1 instanceof t$2; + }(t$1))); + }, + shape: function(t$1) { + return a(p(u(t$1))); + } +}; +var I = class extends Error { + constructor(t$1) { + let e$1; + try { + e$1 = JSON.stringify(t$1); + } catch (n$1) { + e$1 = t$1; + } + super(`Pattern matching error: no pattern matches value ${e$1}`), this.input = void 0, this.input = t$1; + } +}; +var L = { + matched: !1, + value: void 0 +}; +function M(t$1) { + return new R(t$1, L); +} +var R = class R { + constructor(t$1, e$1) { + this.input = void 0, this.state = void 0, this.input = t$1, this.state = e$1; + } + with(...t$1) { + if (this.state.matched) return this; + const e$1 = t$1[t$1.length - 1], r$1 = [t$1[0]]; + let i$1; + 3 === t$1.length && "function" == typeof t$1[1] ? i$1 = t$1[1] : t$1.length > 2 && r$1.push(...t$1.slice(1, t$1.length - 1)); + let s$1 = !1, c$1 = {}; + const u$1 = (t$2, e$2) => { + s$1 = !0, c$1[t$2] = e$2; + }, a$1 = !r$1.some((t$2) => o(t$2, this.input, u$1)) || i$1 && !Boolean(i$1(this.input)) ? L : { + matched: !0, + value: e$1(s$1 ? n in c$1 ? c$1[n] : c$1 : this.input, this.input) + }; + return new R(this.input, a$1); + } + when(t$1, e$1) { + if (this.state.matched) return this; + const n$1 = Boolean(t$1(this.input)); + return new R(this.input, n$1 ? { + matched: !0, + value: e$1(this.input, this.input) + } : L); + } + otherwise(t$1) { + return this.state.matched ? this.state.value : t$1(this.input); + } + exhaustive(t$1 = F) { + return this.state.matched ? this.state.value : t$1(this.input); + } + run() { + return this.exhaustive(); + } + returnType() { + return this; + } + narrow() { + return this; + } +}; +function F(t$1) { + throw new I(t$1); +} + +//#endregion +export { z as n, M as t }; +//# sourceMappingURL=dist.CzYTlmnN.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js.map b/web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js.map new file mode 100644 index 00000000..e1c6285f --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/dist.CzYTlmnN.js.map @@ -0,0 +1 @@ +{"version":3,"file":"dist.CzYTlmnN.js","names":["t","e","n","r","i","s","c","u","o","a"],"sources":["../../../../../../node_modules/ts-pattern/dist/index.js"],"sourcesContent":["const t=Symbol.for(\"@ts-pattern/matcher\"),e=Symbol.for(\"@ts-pattern/isVariadic\"),n=\"@ts-pattern/anonymous-select-key\",r=t=>Boolean(t&&\"object\"==typeof t),i=e=>e&&!!e[t],o=(n,s,c)=>{if(i(n)){const e=n[t](),{matched:r,selections:i}=e.match(s);return r&&i&&Object.keys(i).forEach(t=>c(t,i[t])),r}if(r(n)){if(!r(s))return!1;if(Array.isArray(n)){if(!Array.isArray(s))return!1;let t=[],r=[],u=[];for(const o of n.keys()){const s=n[o];i(s)&&s[e]?u.push(s):u.length?r.push(s):t.push(s)}if(u.length){if(u.length>1)throw new Error(\"Pattern error: Using `...P.array(...)` several times in a single pattern is not allowed.\");if(s.lengtho(t,e[n],c))&&r.every((t,e)=>o(t,n[e],c))&&(0===u.length||o(u[0],i,c))}return n.length===s.length&&n.every((t,e)=>o(t,s[e],c))}return Reflect.ownKeys(n).every(e=>{const r=n[e];return(e in s||i(u=r)&&\"optional\"===u[t]().matcherType)&&o(r,s[e],c);var u})}return Object.is(s,n)},s=e=>{var n,o,u;return r(e)?i(e)?null!=(n=null==(o=(u=e[t]()).getSelectionKeys)?void 0:o.call(u))?n:[]:Array.isArray(e)?c(e,s):c(Object.values(e),s):[]},c=(t,e)=>t.reduce((t,n)=>t.concat(e(n)),[]);function u(...t){if(1===t.length){const[e]=t;return t=>o(e,t,()=>{})}if(2===t.length){const[e,n]=t;return o(e,n,()=>{})}throw new Error(`isMatching wasn't given the right number of arguments: expected 1 or 2, received ${t.length}.`)}function a(t){return Object.assign(t,{optional:()=>h(t),and:e=>d(t,e),or:e=>y(t,e),select:e=>void 0===e?v(t):v(e,t)})}function l(t){return Object.assign((t=>Object.assign(t,{[Symbol.iterator](){let n=0;const r=[{value:Object.assign(t,{[e]:!0}),done:!1},{done:!0,value:void 0}];return{next:()=>{var t;return null!=(t=r[n++])?t:r.at(-1)}}}}))(t),{optional:()=>l(h(t)),select:e=>l(void 0===e?v(t):v(e,t))})}function h(e){return a({[t]:()=>({match:t=>{let n={};const r=(t,e)=>{n[t]=e};return void 0===t?(s(e).forEach(t=>r(t,void 0)),{matched:!0,selections:n}):{matched:o(e,t,r),selections:n}},getSelectionKeys:()=>s(e),matcherType:\"optional\"})})}const f=(t,e)=>{for(const n of t)if(!e(n))return!1;return!0},g=(t,e)=>{for(const[n,r]of t.entries())if(!e(r,n))return!1;return!0},m=(t,e)=>{const n=Reflect.ownKeys(t);for(const r of n)if(!e(r,t[r]))return!1;return!0};function d(...e){return a({[t]:()=>({match:t=>{let n={};const r=(t,e)=>{n[t]=e};return{matched:e.every(e=>o(e,t,r)),selections:n}},getSelectionKeys:()=>c(e,s),matcherType:\"and\"})})}function y(...e){return a({[t]:()=>({match:t=>{let n={};const r=(t,e)=>{n[t]=e};return c(e,s).forEach(t=>r(t,void 0)),{matched:e.some(e=>o(e,t,r)),selections:n}},getSelectionKeys:()=>c(e,s),matcherType:\"or\"})})}function p(e){return{[t]:()=>({match:t=>({matched:Boolean(e(t))})})}}function v(...e){const r=\"string\"==typeof e[0]?e[0]:void 0,i=2===e.length?e[1]:\"string\"==typeof e[0]?void 0:e[0];return a({[t]:()=>({match:t=>{let e={[null!=r?r:n]:t};return{matched:void 0===i||o(i,t,(t,n)=>{e[t]=n}),selections:e}},getSelectionKeys:()=>[null!=r?r:n].concat(void 0===i?[]:s(i))})})}function b(t){return!0}function w(t){return\"number\"==typeof t}function S(t){return\"string\"==typeof t}function j(t){return\"bigint\"==typeof t}const K=a(p(b)),O=a(p(b)),E=K,x=t=>Object.assign(a(t),{startsWith:e=>{return x(d(t,(n=e,p(t=>S(t)&&t.startsWith(n)))));var n},endsWith:e=>{return x(d(t,(n=e,p(t=>S(t)&&t.endsWith(n)))));var n},minLength:e=>x(d(t,(t=>p(e=>S(e)&&e.length>=t))(e))),length:e=>x(d(t,(t=>p(e=>S(e)&&e.length===t))(e))),maxLength:e=>x(d(t,(t=>p(e=>S(e)&&e.length<=t))(e))),includes:e=>{return x(d(t,(n=e,p(t=>S(t)&&t.includes(n)))));var n},regex:e=>{return x(d(t,(n=e,p(t=>S(t)&&Boolean(t.match(n))))));var n}}),A=x(p(S)),N=t=>Object.assign(a(t),{between:(e,n)=>N(d(t,((t,e)=>p(n=>w(n)&&t<=n&&e>=n))(e,n))),lt:e=>N(d(t,(t=>p(e=>w(e)&&eN(d(t,(t=>p(e=>w(e)&&e>t))(e))),lte:e=>N(d(t,(t=>p(e=>w(e)&&e<=t))(e))),gte:e=>N(d(t,(t=>p(e=>w(e)&&e>=t))(e))),int:()=>N(d(t,p(t=>w(t)&&Number.isInteger(t)))),finite:()=>N(d(t,p(t=>w(t)&&Number.isFinite(t)))),positive:()=>N(d(t,p(t=>w(t)&&t>0))),negative:()=>N(d(t,p(t=>w(t)&&t<0)))}),P=N(p(w)),k=t=>Object.assign(a(t),{between:(e,n)=>k(d(t,((t,e)=>p(n=>j(n)&&t<=n&&e>=n))(e,n))),lt:e=>k(d(t,(t=>p(e=>j(e)&&ek(d(t,(t=>p(e=>j(e)&&e>t))(e))),lte:e=>k(d(t,(t=>p(e=>j(e)&&e<=t))(e))),gte:e=>k(d(t,(t=>p(e=>j(e)&&e>=t))(e))),positive:()=>k(d(t,p(t=>j(t)&&t>0))),negative:()=>k(d(t,p(t=>j(t)&&t<0)))}),T=k(p(j)),B=a(p(function(t){return\"boolean\"==typeof t})),_=a(p(function(t){return\"symbol\"==typeof t})),W=a(p(function(t){return null==t})),$=a(p(function(t){return null!=t}));var z={__proto__:null,matcher:t,optional:h,array:function(...e){return l({[t]:()=>({match:t=>{if(!Array.isArray(t))return{matched:!1};if(0===e.length)return{matched:!0};const n=e[0];let r={};if(0===t.length)return s(n).forEach(t=>{r[t]=[]}),{matched:!0,selections:r};const i=(t,e)=>{r[t]=(r[t]||[]).concat([e])};return{matched:t.every(t=>o(n,t,i)),selections:r}},getSelectionKeys:()=>0===e.length?[]:s(e[0])})})},set:function(...e){return a({[t]:()=>({match:t=>{if(!(t instanceof Set))return{matched:!1};let n={};if(0===t.size)return{matched:!0,selections:n};if(0===e.length)return{matched:!0};const r=(t,e)=>{n[t]=(n[t]||[]).concat([e])},i=e[0];return{matched:f(t,t=>o(i,t,r)),selections:n}},getSelectionKeys:()=>0===e.length?[]:s(e[0])})})},map:function(...e){return a({[t]:()=>({match:t=>{if(!(t instanceof Map))return{matched:!1};let n={};if(0===t.size)return{matched:!0,selections:n};const r=(t,e)=>{n[t]=(n[t]||[]).concat([e])};if(0===e.length)return{matched:!0};var i;if(1===e.length)throw new Error(`\\`P.map\\` wasn't given enough arguments. Expected (key, value), received ${null==(i=e[0])?void 0:i.toString()}`);const[s,c]=e;return{matched:g(t,(t,e)=>{const n=o(s,e,r),i=o(c,t,r);return n&&i}),selections:n}},getSelectionKeys:()=>0===e.length?[]:[...s(e[0]),...s(e[1])]})})},record:function(...e){return a({[t]:()=>({match:t=>{if(null===t||\"object\"!=typeof t||Array.isArray(t))return{matched:!1};var n;if(0===e.length)throw new Error(`\\`P.record\\` wasn't given enough arguments. Expected (value) or (key, value), received ${null==(n=e[0])?void 0:n.toString()}`);let r={};const i=(t,e)=>{r[t]=(r[t]||[]).concat([e])},[s,c]=1===e.length?[A,e[0]]:e;return{matched:m(t,(t,e)=>{const n=\"string\"!=typeof t||Number.isNaN(Number(t))?null:Number(t),r=null!==n&&o(s,n,i),u=o(s,t,i),a=o(c,e,i);return(u||r)&&a}),selections:r}},getSelectionKeys:()=>0===e.length?[]:[...s(e[0]),...s(e[1])]})})},intersection:d,union:y,not:function(e){return a({[t]:()=>({match:t=>({matched:!o(e,t,()=>{})}),getSelectionKeys:()=>[],matcherType:\"not\"})})},when:p,select:v,any:K,unknown:O,_:E,string:A,number:P,bigint:T,boolean:B,symbol:_,nullish:W,nonNullable:$,instanceOf:function(t){return a(p(function(t){return e=>e instanceof t}(t)))},shape:function(t){return a(p(u(t)))}};class I extends Error{constructor(t){let e;try{e=JSON.stringify(t)}catch(n){e=t}super(`Pattern matching error: no pattern matches value ${e}`),this.input=void 0,this.input=t}}const L={matched:!1,value:void 0};function M(t){return new R(t,L)}class R{constructor(t,e){this.input=void 0,this.state=void 0,this.input=t,this.state=e}with(...t){if(this.state.matched)return this;const e=t[t.length-1],r=[t[0]];let i;3===t.length&&\"function\"==typeof t[1]?i=t[1]:t.length>2&&r.push(...t.slice(1,t.length-1));let s=!1,c={};const u=(t,e)=>{s=!0,c[t]=e},a=!r.some(t=>o(t,this.input,u))||i&&!Boolean(i(this.input))?L:{matched:!0,value:e(s?n in c?c[n]:c:this.input,this.input)};return new R(this.input,a)}when(t,e){if(this.state.matched)return this;const n=Boolean(t(this.input));return new R(this.input,n?{matched:!0,value:e(this.input,this.input)}:L)}otherwise(t){return this.state.matched?this.state.value:t(this.input)}exhaustive(t=F){return this.state.matched?this.state.value:t(this.input)}run(){return this.exhaustive()}returnType(){return this}narrow(){return this}}function F(t){throw new I(t)}export{I as NonExhaustiveError,z as P,z as Pattern,u as isMatching,M as match};\n//# sourceMappingURL=index.js.map\n"],"x_google_ignoreList":[0],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js b/web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js new file mode 100644 index 00000000..fe29f23e --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js @@ -0,0 +1,3069 @@ +import { r as _defineProperty, t as logger } from "./journalisation.CEgm28xa.js"; +import { dt as pipe, n as captureException } from "./exports.CurVqjr0.js"; + +//#region node_modules/@mobily/ts-belt/dist/caml-aa4fccd9.mjs +function int_compare(e, r) { + if (e < r) return -1; + else if (e === r) return 0; + else return 1; +} +function bool_compare(e, r) { + if (e) if (r) return 0; + else return 1; + else if (r) return -1; + else return 0; +} +function string_compare(e, r) { + if (e === r) return 0; + else if (e < r) return -1; + else return 1; +} +function int_max(e, r) { + if (e > r) return e; + else return r; +} + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/caml_obj-c29533cc.mjs +var for_in = function(r, e) { + for (var n in r) e(n); +}; +function compare(t, a) { + if (t === a) return 0; + var i$1 = typeof t; + var u = typeof a; + switch (i$1) { + case "boolean": + if ("boolean" === u) return bool_compare(t, a); + break; + case "function": + if ("function" === u) throw { + RE_EXN_ID: "Invalid_argument", + _1: "compare: functional value", + Error: /* @__PURE__ */ new Error() + }; + break; + case "number": + if ("number" === u) return int_compare(t, a); + break; + case "string": if ("string" === u) return string_compare(t, a); + else return 1; + case "undefined": return -1; + } + switch (u) { + case "string": return -1; + case "undefined": return 1; + default: + if ("boolean" === i$1) return 1; + if ("boolean" === u) return -1; + if ("function" === i$1) return 1; + if ("function" === u) return -1; + if ("number" === i$1) if (null === a || void 0 !== a.BS_PRIVATE_NESTED_SOME_NONE) return 1; + else return -1; + if ("number" === u) if (null === t || void 0 !== t.BS_PRIVATE_NESTED_SOME_NONE) return -1; + else return 1; + if (null === t) if (void 0 !== a.BS_PRIVATE_NESTED_SOME_NONE) return 1; + else return -1; + if (null === a) if (void 0 !== t.BS_PRIVATE_NESTED_SOME_NONE) return -1; + else return 1; + if (void 0 !== t.BS_PRIVATE_NESTED_SOME_NONE) if (void 0 !== a.BS_PRIVATE_NESTED_SOME_NONE) return aux_obj_compare(t, a); + else return -1; + var o = 0 | t.TAG; + var f = 0 | a.TAG; + if (248 === o) return int_compare(t[1], a[1]); + if (251 === o) throw { + RE_EXN_ID: "Invalid_argument", + _1: "equal: abstract value", + Error: /* @__PURE__ */ new Error() + }; + if (o !== f) if (o < f) return -1; + else return 1; + var l = 0 | t.length; + var s = 0 | a.length; + if (l === s) if (Array.isArray(t)) { + var c = 0; + while (1) { + var v = c; + if (v === l) return 0; + var E = compare(t[v], a[v]); + if (0 !== E) return E; + c = v + 1 | 0; + } + } else if (t instanceof Date && a instanceof Date) return t - a; + else return aux_obj_compare(t, a); + else if (l < s) { + var _ = 0; + while (1) { + var d = _; + if (d === l) return -1; + var p = compare(t[d], a[d]); + if (0 !== p) return p; + _ = d + 1 | 0; + } + } else { + var m = 0; + while (1) { + var b = m; + if (b === s) return 1; + var N$1 = compare(t[b], a[b]); + if (0 !== N$1) return N$1; + m = b + 1 | 0; + } + } + } +} +function aux_obj_compare(e, n) { + var t = { contents: void 0 }; + var a = { contents: void 0 }; + var do_key = function(r, e$1) { + var n$1 = r[2]; + var t$1 = r[1]; + if (Object.prototype.hasOwnProperty.call(t$1, e$1) && !(compare(r[0][e$1], t$1[e$1]) > 0)) return; + var a$1 = n$1.contents; + if (void 0 !== a$1 && e$1 >= a$1) return; + else { + n$1.contents = e$1; + return; + } + }; + var i$1 = [ + e, + n, + a + ]; + var u = [ + n, + e, + t + ]; + for_in(e, (function(r) { + return do_key(i$1, r); + })); + for_in(n, (function(r) { + return do_key(u, r); + })); + var o = t.contents; + var f = a.contents; + if (void 0 !== o) if (void 0 !== f) return string_compare(o, f); + else return -1; + else if (void 0 !== f) return 1; + else return 0; +} +function equal(r, e) { + if (r === e) return !0; + var n = typeof r; + if ("string" === n || "number" === n || "boolean" === n || "undefined" === n || null === r) return !1; + var t = typeof e; + if ("function" === n || "function" === t) throw { + RE_EXN_ID: "Invalid_argument", + _1: "equal: functional value", + Error: /* @__PURE__ */ new Error() + }; + if ("number" === t || "undefined" === t || null === e) return !1; + var a = 0 | r.TAG; + var i$1 = 0 | e.TAG; + if (248 === a) return r[1] === e[1]; + if (251 === a) throw { + RE_EXN_ID: "Invalid_argument", + _1: "equal: abstract value", + Error: /* @__PURE__ */ new Error() + }; + if (a !== i$1) return !1; + var u = 0 | r.length; + if (u === (0 | e.length)) if (Array.isArray(r)) { + var o = 0; + while (1) { + var f = o; + if (f === u) return !0; + if (!equal(r[f], e[f])) return !1; + o = f + 1 | 0; + } + } else if (r instanceof Date && e instanceof Date) return !(r > e || r < e); + else { + var l = { contents: !0 }; + for_in(r, (function(r$1) { + if (!Object.prototype.hasOwnProperty.call(e, r$1)) { + l.contents = !1; + return; + } + })); + if (l.contents) for_in(e, (function(n$1) { + if (!Object.prototype.hasOwnProperty.call(r, n$1) || !equal(e[n$1], r[n$1])) { + l.contents = !1; + return; + } + })); + return l.contents; + } + else return !1; +} +function lessthan(r, e) { + return compare(r, e) < 0; +} + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/caml_option-16487d6d.mjs +function some$1(_) { + if (void 0 === _) return { BS_PRIVATE_NESTED_SOME_NONE: 0 }; + else if (null !== _ && void 0 !== _.BS_PRIVATE_NESTED_SOME_NONE) return { BS_PRIVATE_NESTED_SOME_NONE: _.BS_PRIVATE_NESTED_SOME_NONE + 1 | 0 }; + else return _; +} +function nullable_to_opt(_) { + if (null == _) return; + else return some$1(_); +} +function valFromOption(_) { + if (null === _ || void 0 === _.BS_PRIVATE_NESTED_SOME_NONE) return _; + var n = _.BS_PRIVATE_NESTED_SOME_NONE; + if (0 === n) return; + else return { BS_PRIVATE_NESTED_SOME_NONE: n - 1 | 0 }; +} + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/belt_Array-b9ebcaa6.mjs +function floor_int(r) { + if (r > 2147483647) return 2147483647; + else if (r < -2147483648) return -2147483648; + else return Math.floor(r); +} +function random_int(r, n) { + return floor_int(Math.random() * (n - r | 0)) + r | 0; +} +function get$1(r, a) { + if (a >= 0 && a < r.length) return some$1(r[a]); +} +function getExn(r, n) { + if (!(n >= 0 && n < r.length)) throw { + RE_EXN_ID: "Assert_failure", + _1: [ + "belt_Array.ml", + 35, + 2 + ], + Error: /* @__PURE__ */ new Error() + }; + return r[n]; +} +function swapUnsafe(r, n, a) { + var e = r[n]; + r[n] = r[a]; + r[a] = e; +} +function shuffle(r) { + var n = r.slice(0); + (function shuffleInPlace(r$1) { + var n$1 = r$1.length; + for (var a = 0; a < n$1; ++a) swapUnsafe(r$1, a, random_int(a, n$1)); + })(n); + return n; +} +function reverse(r) { + var n = r.length; + var a = new Array(n); + for (var e = 0; e < n; ++e) a[e] = r[(n - 1 | 0) - e | 0]; + return a; +} +function make$1(r, n) { + if (r <= 0) return []; + var a = new Array(r); + for (var e = 0; e < r; ++e) a[e] = n; + return a; +} +function makeByU(r, n) { + if (r <= 0) return []; + var a = new Array(r); + for (var e = 0; e < r; ++e) a[e] = n(e); + return a; +} +function range$1(r, n) { + var a = n - r | 0; + if (a < 0) return []; + var e = new Array(a + 1 | 0); + for (var t = 0; t <= a; ++t) e[t] = r + t | 0; + return e; +} +function rangeBy$1(r, n, a) { + var e = n - r | 0; + if (e < 0 || a <= 0) return []; + var t = 1 + (e / a | 0) | 0; + var v = new Array(t); + var f = r; + for (var o = 0; o < t; ++o) { + v[o] = f; + f = f + a | 0; + } + return v; +} +function zip$1(r, n) { + var a = r.length; + var e = n.length; + var t = a < e ? a : e; + var v = new Array(t); + for (var f = 0; f < t; ++f) v[f] = [r[f], n[f]]; + return v; +} +function zipByU(r, n, a) { + var e = r.length; + var t = n.length; + var v = e < t ? e : t; + var f = new Array(v); + for (var o = 0; o < v; ++o) f[o] = a(r[o], n[o]); + return f; +} +function concat$1(r, n) { + var a = r.length; + var e = n.length; + var t = new Array(a + e | 0); + for (var v = 0; v < a; ++v) t[v] = r[v]; + for (var f = 0; f < e; ++f) t[a + f | 0] = n[f]; + return t; +} +function concatMany(r) { + var n = r.length; + var a = 0; + for (var e = 0; e < n; ++e) a = a + r[e].length | 0; + var t = new Array(a); + a = 0; + for (var v = 0; v < n; ++v) { + var f = r[v]; + for (var o = 0, i$1 = f.length; o < i$1; ++o) { + t[a] = f[o]; + a = a + 1 | 0; + } + } + return t; +} +function slice$1(n, a, e) { + if (e <= 0) return []; + var t = n.length; + var v = a < 0 ? int_max(t + a | 0, 0) : a; + var f = t - v | 0; + var o = f < e ? f : e; + if (o <= 0) return []; + var i$1 = new Array(o); + for (var u = 0; u < o; ++u) i$1[u] = n[v + u | 0]; + return i$1; +} +function sliceToEnd$1(n, a) { + var e = n.length; + var t = a < 0 ? int_max(e + a | 0, 0) : a; + var v = e > t ? e - t | 0 : 0; + var f = new Array(v); + for (var o = 0; o < v; ++o) f[o] = n[t + o | 0]; + return f; +} +function blitUnsafe(r, n, a, e, t) { + if (e <= n) { + for (var v = 0; v < t; ++v) a[v + e | 0] = r[v + n | 0]; + return; + } + for (var f = t - 1 | 0; f >= 0; --f) a[f + e | 0] = r[f + n | 0]; +} +function forEachU(r, n) { + for (var a = 0, e = r.length; a < e; ++a) n(r[a]); +} +function mapU(r, n) { + var a = r.length; + var e = new Array(a); + for (var t = 0; t < a; ++t) e[t] = n(r[t]); + return e; +} +function getByU(r, a) { + var e = r.length; + var t = 0; + var v; + while (void 0 === v && t < e) { + var f = r[t]; + if (a(f)) v = some$1(f); + t = t + 1 | 0; + } + return v; +} +function getIndexByU(r, n) { + var a = r.length; + var e = 0; + var t; + while (void 0 === t && e < a) { + if (n(r[e])) t = e; + e = e + 1 | 0; + } + return t; +} +function keepMapU(r, n) { + var e = r.length; + var t = new Array(e); + var v = 0; + for (var f = 0; f < e; ++f) { + var o = n(r[f]); + if (void 0 !== o) { + t[v] = valFromOption(o); + v = v + 1 | 0; + } + } + t.length = v; + return t; +} +function forEachWithIndexU(r, n) { + for (var a = 0, e = r.length; a < e; ++a) n(a, r[a]); +} +function mapWithIndexU(r, n) { + var a = r.length; + var e = new Array(a); + for (var t = 0; t < a; ++t) e[t] = n(t, r[t]); + return e; +} +function reduceU(r, n, a) { + var e = n; + for (var t = 0, v = r.length; t < v; ++t) e = a(e, r[t]); + return e; +} +function reduceReverseU(r, n, a) { + var e = n; + for (var t = r.length - 1 | 0; t >= 0; --t) e = a(e, r[t]); + return e; +} +function reduceWithIndexU(r, n, a) { + var e = n; + for (var t = 0, v = r.length; t < v; ++t) e = a(e, r[t], t); + return e; +} +function everyU(r, n) { + var a = r.length; + var e = 0; + while (1) { + var t = e; + if (t === a) return !0; + if (!n(r[t])) return !1; + e = t + 1 | 0; + } +} +function someU(r, n) { + var a = r.length; + var e = 0; + while (1) { + var t = e; + if (t === a) return !1; + if (n(r[t])) return !0; + e = t + 1 | 0; + } +} +function eqU(r, n, a) { + var e = r.length; + if (e === n.length) return function everyAux2(r$1, n$1, a$1, e$1, t) { + while (1) { + var v = a$1; + if (v === t) return !0; + if (!e$1(r$1[v], n$1[v])) return !1; + a$1 = v + 1 | 0; + } + }(r, n, 0, a, e); + else return !1; +} +function partitionU(r, n) { + var a = r.length; + var e = 0; + var t = 0; + var v = new Array(a); + var f = new Array(a); + for (var o = 0; o < a; ++o) { + var i$1 = r[o]; + if (n(i$1)) { + v[e] = i$1; + e = e + 1 | 0; + } else { + f[t] = i$1; + t = t + 1 | 0; + } + } + v.length = e; + f.length = t; + return [v, f]; +} +function unzip(r) { + var n = r.length; + var a = new Array(n); + var e = new Array(n); + for (var t = 0; t < n; ++t) { + var v = r[t]; + a[t] = v[0]; + e[t] = v[1]; + } + return [a, e]; +} + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/Array.bs-4b4ec77c.mjs +function merge(n, t, e, u, i$1, f, a, o, c) { + var s = t + e | 0; + var l = i$1 + f | 0; + var h = t; + var p = n[t]; + var v = i$1; + var g = u[i$1]; + var _ = o; + while (1) { + var d = _; + var y = g; + var m = v; + var A = p; + var x = h; + if (c(A, y) <= 0) { + a[d] = A; + var B = x + 1 | 0; + if (B >= s) return blitUnsafe(u, m, a, d + 1 | 0, l - m | 0); + _ = d + 1 | 0; + p = n[B]; + h = B; + continue; + } + a[d] = y; + var W = m + 1 | 0; + if (W >= l) return blitUnsafe(n, x, a, d + 1 | 0, s - x | 0); + _ = d + 1 | 0; + g = u[W]; + v = W; + } +} +function insertionSort(n, t, r, e, u, i$1) { + for (var f = 0; f < u; ++f) { + var a = n[t + f | 0]; + var o = (e + f | 0) - 1 | 0; + while (o >= e && i$1(r[o], a) > 0) { + r[o + 1 | 0] = r[o]; + o = o - 1 | 0; + } + r[o + 1 | 0] = a; + } +} +function sortTo(n, t, r, e, u, i$1) { + if (u <= 5) return insertionSort(n, t, r, e, u, i$1); + var f = u / 2 | 0; + var a = u - f | 0; + sortTo(n, t + f | 0, r, e + f | 0, a, i$1); + sortTo(n, t, n, t + a | 0, f, i$1); + merge(n, t + a | 0, f, r, e + f | 0, a, r, e, i$1); +} +function stableSortByU(n, t) { + var r = n.slice(0); + (function stableSortInPlaceByU(n$1, t$1) { + var r$1 = n$1.length; + if (r$1 <= 5) return insertionSort(n$1, 0, n$1, 0, r$1, t$1); + var e = r$1 / 2 | 0; + var u = r$1 - e | 0; + var i$1 = new Array(u); + sortTo(n$1, e, i$1, 0, u, t$1); + sortTo(n$1, 0, n$1, u, e, t$1); + merge(n$1, u, e, i$1, 0, u, n$1, 0, t$1); + })(r, t); + return r; +} +function get$1$1(t, r) { + if (r in t) return some$1(t[r]); +} +var unsafeDeleteKey = function(n, t) { + delete n[t]; +}; +function values(n) { + var t = Object.keys(n); + var r = t.length; + var e = new Array(r); + for (var u = 0; u < r; ++u) e[u] = n[t[u]]; + return e; +} +function fromArray(n) { + var t = {}; + var r = n.length; + for (var e = 0; e < r; ++e) { + var u = n[e]; + t[u[0]] = u[1]; + } + return t; +} +function placeholder(n) {} +function makeEmpty(n) { + return []; +} +var z = makeByU; +function makeWithIndex() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return z(t, n[0]); + }; + } + return z(arguments[0], arguments[1]); +} +var S = make$1; +function make() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return S(t, n[0]); + }; + } + return S(arguments[0], arguments[1]); +} +var O = make$1; +function repeat() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return O(t, n[0]); + }; + } + return O(arguments[0], arguments[1]); +} +function length(n) { + return n.length; +} +function isEmpty(n) { + return 0 === n.length; +} +function isNotEmpty(n) { + return 0 !== n.length; +} +var $ = reverse; +function _append(n, t) { + return concat$1(n, [t]); +} +function append() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _append(t, n[0]); + }; + } + return _append(arguments[0], arguments[1]); +} +function _prepend(n, t) { + return concat$1([t], n); +} +function prepend() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _prepend(t, n[0]); + }; + } + return _prepend(arguments[0], arguments[1]); +} +function _prependToAll(n, t) { + return reduceU(n, [], (function(n$1, r) { + return concat$1(n$1, [t, r]); + })); +} +function prependToAll() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _prependToAll(t, n[0]); + }; + } + return _prependToAll(arguments[0], arguments[1]); +} +function _intersperse(n, t) { + return reduceWithIndexU(n, [], (function(r, e, u) { + if ((n.length - 1 | 0) === u) r.push(e); + else r.push(e, t); + return r; + })); +} +function intersperse() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _intersperse(t, n[0]); + }; + } + return _intersperse(arguments[0], arguments[1]); +} +var C = get$1; +function get() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return C(t, n[0]); + }; + } + return C(arguments[0], arguments[1]); +} +var D = get$1; +function at() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return D(t, n[0]); + }; + } + return D(arguments[0], arguments[1]); +} +function _getUnsafe(n, t) { + return n[t]; +} +function getUnsafe() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _getUnsafe(t, n[0]); + }; + } + return _getUnsafe(arguments[0], arguments[1]); +} +function _getUndefined(n, t) { + return n[t]; +} +function getUndefined() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _getUndefined(t, n[0]); + }; + } + return _getUndefined(arguments[0], arguments[1]); +} +var N = getByU; +function getBy() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return N(t, n[0]); + }; + } + return N(arguments[0], arguments[1]); +} +var R = getByU; +function find() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return R(t, n[0]); + }; + } + return R(arguments[0], arguments[1]); +} +function head(n) { + return get$1(n, 0); +} +function last(n) { + var t = n.length; + if (0 === t) return; + else return get$1(n, t - 1 | 0); +} +function tail(n) { + var t = n.length; + if (1 === t) return []; + if (0 === t) return; + var r = sliceToEnd$1(n, 1); + if (0 !== r.length) return r; +} +function tailOrEmpty(n) { + var t = tail(n); + if (void 0 !== t) return t; + else return []; +} +function init(n) { + var t = n.length; + if (0 === t) return; + else return slice$1(n, 0, t - 1 | 0); +} +function initOrEmpty(n) { + var t = init(n); + if (void 0 !== t) return t; + else return []; +} +function _take(n, t) { + var r = n.length; + return slice$1(n, 0, t < 0 ? 0 : r < t ? r : t); +} +function take() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _take(t, n[0]); + }; + } + return _take(arguments[0], arguments[1]); +} +function _takeExactly(n, t) { + if (t < 0 || t > n.length) return; + else return slice$1(n, 0, t); +} +function takeExactly() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _takeExactly(t, n[0]); + }; + } + return _takeExactly(arguments[0], arguments[1]); +} +function _takeWhile(n, t) { + var r = 0; + var e = !1; + var u = []; + while (r < n.length && !e) { + var i$1 = n[r]; + if (t(i$1)) { + u.push(i$1); + r = r + 1 | 0; + } else e = !0; + } + return u; +} +function takeWhile() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _takeWhile(t, n[0]); + }; + } + return _takeWhile(arguments[0], arguments[1]); +} +function _drop(n, t) { + var r = n.length; + return sliceToEnd$1(n, t < 0 ? 0 : r < t ? r : t); +} +function drop() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _drop(t, n[0]); + }; + } + return _drop(arguments[0], arguments[1]); +} +function _dropExactly(n, t) { + if (t < 0 || t > n.length) return; + else return sliceToEnd$1(n, t); +} +function dropExactly() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _dropExactly(t, n[0]); + }; + } + return _dropExactly(arguments[0], arguments[1]); +} +function _dropWhile(n, t) { + return reduceU(n, [], (function(n$1, r) { + if (!t(r)) n$1.push(r); + return n$1; + })); +} +function dropWhile() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _dropWhile(t, n[0]); + }; + } + return _dropWhile(arguments[0], arguments[1]); +} +function uncons(n) { + if (0 !== n.length) return [getExn(n, 0), sliceToEnd$1(n, 1)]; +} +function _map(n, t) { + return mapU(n, t); +} +function map() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _map(t, n[0]); + }; + } + return _map(arguments[0], arguments[1]); +} +var G = mapWithIndexU; +function mapWithIndex() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return G(t, n[0]); + }; + } + return G(arguments[0], arguments[1]); +} +function _filter(n, t) { + var r = 0; + var e = []; + while (r < n.length) { + var u = n[r]; + if (t(u)) e.push(u); + r = r + 1 | 0; + } + return e; +} +function filter() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _filter(t, n[0]); + }; + } + return _filter(arguments[0], arguments[1]); +} +var P = filter; +function _filterWithIndex(n, t) { + var r = 0; + var e = []; + while (r < n.length) { + var u = n[r]; + if (t(r, u)) e.push(u); + r = r + 1 | 0; + } + return e; +} +function filterWithIndex() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _filterWithIndex(t, n[0]); + }; + } + return _filterWithIndex(arguments[0], arguments[1]); +} +var H = filterWithIndex; +function _reject(n, t) { + return filter(n, (function(n$1) { + return !t(n$1); + })); +} +function reject() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _reject(t, n[0]); + }; + } + return _reject(arguments[0], arguments[1]); +} +function _rejectWithIndex(n, t) { + return filterWithIndex(n, (function(n$1, r) { + return !t(n$1, r); + })); +} +function rejectWithIndex() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _rejectWithIndex(t, n[0]); + }; + } + return _rejectWithIndex(arguments[0], arguments[1]); +} +var J = reduceU; +function reduce() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return J(t, n[0], n[1]); + }; + } + return J(arguments[0], arguments[1], arguments[2]); +} +var K = reduceReverseU; +function reduceReverse() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return K(t, n[0], n[1]); + }; + } + return K(arguments[0], arguments[1], arguments[2]); +} +var L = reduceWithIndexU; +function reduceWithIndex() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return L(t, n[0], n[1]); + }; + } + return L(arguments[0], arguments[1], arguments[2]); +} +function _splitAt(n, t) { + if (t < 0 || t > n.length) return; + else return [slice$1(n, 0, t), sliceToEnd$1(n, t)]; +} +function splitAt() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _splitAt(t, n[0]); + }; + } + return _splitAt(arguments[0], arguments[1]); +} +function _splitEvery(n, t) { + if (t < 1 || n.length <= t) return [n]; + var r = 0; + var e = []; + while (r < n.length) { + var u = r + t | 0; + e.push(slice$1(n, r, t)); + r = u; + } + return e; +} +function splitEvery() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _splitEvery(t, n[0]); + }; + } + return _splitEvery(arguments[0], arguments[1]); +} +var Q = shuffle; +var V = partitionU; +function partition() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return V(t, n[0]); + }; + } + return V(arguments[0], arguments[1]); +} +var X = concat$1; +function concat() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return X(t, n[0]); + }; + } + return X(arguments[0], arguments[1]); +} +var Y = concatMany; +var Z = everyU; +function every() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return Z(t, n[0]); + }; + } + return Z(arguments[0], arguments[1]); +} +var nn = someU; +function some() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return nn(t, n[0]); + }; + } + return nn(arguments[0], arguments[1]); +} +var tn = slice$1; +function slice() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return tn(t, n[0], n[1]); + }; + } + return tn(arguments[0], arguments[1], arguments[2]); +} +var rn = sliceToEnd$1; +function sliceToEnd() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return rn(t, n[0]); + }; + } + return rn(arguments[0], arguments[1]); +} +var en = eqU; +function eq() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return en(t, n[0], n[1]); + }; + } + return en(arguments[0], arguments[1], arguments[2]); +} +var un = range$1; +function range() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return un(t, n[0]); + }; + } + return un(arguments[0], arguments[1]); +} +var an = rangeBy$1; +function rangeBy() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return an(t, n[0], n[1]); + }; + } + return an(arguments[0], arguments[1], arguments[2]); +} +function copy(n) { + return n.slice(0); +} +var on = zip$1; +function zip() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return on(t, n[0]); + }; + } + return on(arguments[0], arguments[1]); +} +var cn = zipByU; +function zipWith() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return cn(t, n[0], n[1]); + }; + } + return cn(arguments[0], arguments[1], arguments[2]); +} +var sn = unzip; +function _replaceAt(n, t, r) { + return mapWithIndexU(n, (function(n$1, e) { + if (n$1 === t) return r; + else return e; + })); +} +function replaceAt() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return _replaceAt(t, n[0], n[1]); + }; + } + return _replaceAt(arguments[0], arguments[1], arguments[2]); +} +function _insertAt(n, t, r) { + var e = splitAt(n, t); + if (void 0 !== e) return concat$1(e[0], concat$1([r], e[1])); + else return n; +} +function insertAt() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return _insertAt(t, n[0], n[1]); + }; + } + return _insertAt(arguments[0], arguments[1], arguments[2]); +} +function _updateAt(n, t, r) { + return mapWithIndexU(n, (function(n$1, e) { + if (n$1 === t) return r(e); + else return e; + })); +} +function updateAt() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return _updateAt(t, n[0], n[1]); + }; + } + return _updateAt(arguments[0], arguments[1], arguments[2]); +} +function _swapAt(n, r, e) { + var i$1 = get$1(n, r); + var f = get$1(n, e); + if (void 0 === i$1) return n; + if (void 0 === f) return n; + var a = valFromOption(f); + var o = valFromOption(i$1); + return mapWithIndexU(n, (function(n$1, t) { + if (r === n$1) return a; + else if (e === n$1) return o; + else return t; + })); +} +function swapAt() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return _swapAt(t, n[0], n[1]); + }; + } + return _swapAt(arguments[0], arguments[1], arguments[2]); +} +function _removeAt(n, t) { + return filterWithIndex(n, (function(n$1, r) { + return n$1 !== t; + })); +} +function removeAt() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _removeAt(t, n[0]); + }; + } + return _removeAt(arguments[0], arguments[1]); +} +function _uniqBy(n, t) { + var r = 0; + var e = []; + while (r < n.length) { + var u = n[r]; + if (!someU(e, function(n$1) { + return function(r$1) { + return equal(t(r$1), t(n$1)); + }; + }(u))) e.push(u); + r = r + 1 | 0; + } + return e; +} +function uniqBy() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _uniqBy(t, n[0]); + }; + } + return _uniqBy(arguments[0], arguments[1]); +} +function uniq(n) { + return uniqBy(n, (function(n$1) { + return n$1; + })); +} +var ln = forEachU; +function forEach() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return ln(t, n[0]); + }; + } + return ln(arguments[0], arguments[1]); +} +var hn = forEachWithIndexU; +function forEachWithIndex() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return hn(t, n[0]); + }; + } + return hn(arguments[0], arguments[1]); +} +var pn = getIndexByU; +function getIndexBy() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return pn(t, n[0]); + }; + } + return pn(arguments[0], arguments[1]); +} +function _includes(n, t) { + return someU(n, (function(n$1) { + return equal(n$1, t); + })); +} +function includes$1() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _includes(t, n[0]); + }; + } + return _includes(arguments[0], arguments[1]); +} +function _join(n, t) { + return n.join(t); +} +function join() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _join(t, n[0]); + }; + } + return _join(arguments[0], arguments[1]); +} +var vn = stableSortByU; +function sort() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return vn(t, n[0]); + }; + } + return vn(arguments[0], arguments[1]); +} +function _sortBy(n, t) { + return stableSortByU(n, (function(n$1, r) { + var e = t(n$1); + var u = t(r); + if (e === u) return 0; + else if (lessthan(e, u)) return -1; + else return 1; + })); +} +function sortBy() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _sortBy(t, n[0]); + }; + } + return _sortBy(arguments[0], arguments[1]); +} +function _groupBy(n, t) { + return reduceU(n, {}, (function(n$1, r) { + var e = t(r); + var u = get$1$1(n$1, e); + if (void 0 !== u) u.push(r); + else n$1[e] = [r]; + return n$1; + })); +} +function groupBy() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _groupBy(t, n[0]); + }; + } + return _groupBy(arguments[0], arguments[1]); +} +function flat(n) { + return reduceU(n, [], (function(n$1, t) { + if (Array.isArray(t)) forEachU(t, (function(t$1) { + n$1.push(t$1); + })); + else n$1.push(t); + return n$1; + })); +} +function _flatten(n, t) { + var r = 0; + while (r < n.length) { + var e = n[r]; + if (Array.isArray(e)) flatten(e, t); + else t.push(e); + r = r + 1 | 0; + } + return t; +} +function flatten() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _flatten(t, n[0]); + }; + } + return _flatten(arguments[0], arguments[1]); +} +function deepFlat(n) { + return flatten(n, []); +} +function toTuple(n) { + return n; +} +function _tap(n, t) { + forEachU(n, t); + return n; +} +function tap() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _tap(t, n[0]); + }; + } + return _tap(arguments[0], arguments[1]); +} +function flip(n) { + return [n[1], n[0]]; +} +var gn = keepMapU; +function filterMap() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return gn(t, n[0]); + }; + } + return gn(arguments[0], arguments[1]); +} +var _n = keepMapU; +function keepMap() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _n(t, n[0]); + }; + } + return _n(arguments[0], arguments[1]); +} +function _removeFirstBy(n, t, r) { + return reduceU(n, [!1, []], (function(n$1, e) { + var u = n$1[1]; + if (n$1[0]) { + u.push(e); + return [!0, u]; + } else if (r(e, t)) return [!0, u]; + else { + u.push(e); + return [!1, u]; + } + }))[1]; +} +function removeFirstBy() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t) { + return _removeFirstBy(t, n[0], n[1]); + }; + } + return _removeFirstBy(arguments[0], arguments[1], arguments[2]); +} +function _removeFirst(n, t) { + return removeFirstBy(n, t, equal); +} +function removeFirst() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _removeFirst(t, n[0]); + }; + } + return _removeFirst(arguments[0], arguments[1]); +} +function zipWithIndex(n) { + return reduceWithIndexU(n, [], (function(n$1, t, r) { + n$1.push([t, r]); + return n$1; + })); +} +function _all(n, t) { + return everyU(n, t); +} +function all() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _all(t, n[0]); + }; + } + return _all(arguments[0], arguments[1]); +} +function _any(n, t) { + return someU(n, t); +} +function any() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _any(t, n[0]); + }; + } + return _any(arguments[0], arguments[1]); +} +function _difference(n, t) { + return reject(uniqBy(n, (function(n$1) { + return n$1; + })), (function(n$1) { + return includes$1(t, n$1); + })); +} +function difference() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _difference(t, n[0]); + }; + } + return _difference(arguments[0], arguments[1]); +} +function _union(n, t) { + return uniqBy(concat$1(n, t), (function(n$1) { + return n$1; + })); +} +function union$1() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _union(t, n[0]); + }; + } + return _union(arguments[0], arguments[1]); +} +function _intersection(n, t) { + var r = n.length > t.length ? [n, t] : [t, n]; + var e = r[1]; + return uniqBy(filter(r[0], (function(n$1) { + return includes$1(e, n$1); + })), (function(n$1) { + return n$1; + })); +} +function intersection() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _intersection(t, n[0]); + }; + } + return _intersection(arguments[0], arguments[1]); +} +function sample(n) { + return n[random_int(0, n.length - 1 | 0)]; +} +function _flatMap(n, t) { + return flat(mapU(n, t)); +} +function flatMap() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t) { + return _flatMap(t, n[0]); + }; + } + return _flatMap(arguments[0], arguments[1]); +} + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/index-69bc96f0.mjs +var Ra = { + __proto__: null, + placeholder, + makeEmpty, + makeWithIndex, + make, + repeat, + length, + isEmpty, + isNotEmpty, + reverse: $, + append, + prepend, + prependToAll, + intersperse, + get, + at, + getUnsafe, + getUndefined, + getBy, + find, + head, + last, + tail, + tailOrEmpty, + init, + initOrEmpty, + take, + takeExactly, + takeWhile, + drop, + dropExactly, + dropWhile, + uncons, + map, + mapWithIndex, + filter, + keep: P, + filterWithIndex, + keepWithIndex: H, + reject, + rejectWithIndex, + reduce, + reduceReverse, + reduceWithIndex, + splitAt, + splitEvery, + shuffle: Q, + partition, + concat, + concatMany: Y, + every, + some, + slice, + sliceToEnd, + eq, + range, + rangeBy, + copy, + zip, + zipWith, + unzip: sn, + replaceAt, + insertAt, + updateAt, + swapAt, + removeAt, + uniqBy, + uniq, + forEach, + forEachWithIndex, + getIndexBy, + includes: includes$1, + join, + sort, + sortBy, + groupBy, + flat, + flatten, + deepFlat, + toTuple, + tap, + flip, + filterMap, + keepMap, + removeFirstBy, + removeFirst, + zipWithIndex, + all, + any, + difference, + union: union$1, + intersection, + sample, + flatMap +}; + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/index-e7228f55.mjs +function _is(i$1, n) { + return typeof i$1 === n; +} +function is$1() { + if (1 === arguments.length) { + const i$1 = arguments; + return function fn(n) { + return _is(n, i$1[0]); + }; + } + return _is(arguments[0], arguments[1]); +} +function isString(i$1) { + return "string" == typeof i$1; +} +function isNumber(i$1) { + if ("number" == typeof i$1) return !Number.isNaN(i$1); + else return !1; +} +function isBoolean(i$1) { + return "boolean" == typeof i$1; +} +var isPromise = (i$1) => i$1 instanceof Promise; +function isArray(i$1) { + return Array.isArray(i$1); +} +function isObject(i$1) { + if (i$1 && !Array.isArray(i$1)) return "object" == typeof i$1; + else return !1; +} +function isFunction(i$1) { + return "function" == typeof i$1; +} +var isError = (i$1) => i$1 instanceof Error; +var isDate = (i$1) => i$1 instanceof Date; +function isNullable(i$1) { + return null == i$1; +} +function isNotNullable(i$1) { + return !(null == i$1); +} +var isNull = (i$1) => null === i$1; +var isUndefined = (i$1) => void 0 === i$1; +function _isNot(i$1, n) { + return !n(i$1); +} +function isNot() { + if (1 === arguments.length) { + const i$1 = arguments; + return function fn(n) { + return _isNot(n, i$1[0]); + }; + } + return _isNot(arguments[0], arguments[1]); +} +var i = { + __proto__: null, + is: is$1, + isString, + isNumber, + isBoolean, + isPromise, + isArray, + isObject, + isFunction, + isError, + isDate, + isNullable, + isNotNullable, + isNull, + isUndefined, + isNot +}; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/constantes/dom.ts +/** Constantes de valeurs pour la manipulation du DOM : sélecteurs et attributs. */ +const ATTRIBUT_ACTIF = "data-actif"; +const ATTRIBUT_ARIA_CONTROLS = "aria-controls"; +const ATTRIBUT_ARIA_EXPANDED = "aria-expanded"; +const ATTRIBUT_ARIA_HIDDEN = "aria-hidden"; +const ATTRIBUT_CACHÉ = "data-caché"; +const ATTRIBUT_CHARGEMENT = "data-chargement"; +const ATTRIBUT_CLE_PANIER = "data-cle-panier"; +const ATTRIBUT_CODE_PROMO_PRESENT = "data-code-promo-present"; +const ATTRIBUT_CONTIENT_ARTICLES = "data-contient-articles"; +const ATTRIBUT_DESACTIVE = "disabled"; +const ATTRIBUT_ENSEMBLE_EPINGLE_BOITE_ACTIF = "data-ensemble-epingle-boite-actif"; +const ATTRIBUT_HIDDEN = "hidden"; +const ATTRIBUT_ID_CATEGORIE_PRODUITS = "data-id-categorie-produits"; +const ATTRIBUT_ID_ENSEMBLE_EPINGLE_BOITE = "data-id-ensemble-epingle-boite"; +const ATTRIBUT_LIVRAISON_VALIDEE = "data-livraison-validee"; +const ATTRIBUT_MENU_MOBILE_ACTIVE = "data-menu-mobile-active"; +const ATTRIBUT_PAGE = "data-page"; +const ATTRIBUT_PRIX = "data-prix"; +const ATTRIBUT_TABINDEX = "tabindex"; +const DOM_BOUTON_MENU_MOBILE = "#bouton-menu-mobile"; +const DOM_BOUTON_PANIER = ".compte-panier a[rel='cart']"; +const DOM_ENTREE_MENU_CATEGORIES_PRODUITS = "#menu-categories-produits ul li a"; +const DOM_MENU_CATEGORIES_PRODUITS = "#menu-categories-produits"; +const DOM_MENU_MOBILE = "#menu-mobile"; +const DOM_BOUTON_ACTIONS_FORMULAIRE = "#panneau-informations-client .panneau__pied-de-page button"; +const DOM_BOUTON_ADDITION_QUANTITE = "button.detail-produit__actions__addition"; +const DOM_BOUTON_CODE_PROMO = "#panneau-panier #bouton-code-promo"; +const DOM_BOUTON_SEPARATION_ADRESSES = "#separation-adresses"; +const DOM_BOUTON_SOUSTRACTION_QUANTITE = "button.detail-produit__actions__soustraction"; +const DOM_BOUTON_SUPPRESSION_PANIER = "button.detail-produit__actions__suppression"; +const DOM_CHAMP_CODE_PROMO = "#panneau-panier #champ-code-promo"; +const DOM_CHAMP_QUANTITE_LIGNE_PANIER = "input"; +const DOM_CONTENEUR_METHODES_LIVRAISON = "#panneau-panier #choix-methode-livraison"; +const DOM_ENSEMBLE_CODE_PROMO = "#panneau-panier #ensemble-code-promo"; +const DOM_ENTREES_PANIER = "article"; +const DOM_FORMULAIRE_FACTURATION = "#panneau-informations-client .panneau__formulaires__facturation"; +const DOM_FORMULAIRE_PANIER = "#panneau-informations-client form"; +const DOM_INSTRUCTIONS_CLIENT = "#panneau-panier #instructions-client"; +const DOM_MESSAGE_CODE_PROMO = "#panneau-panier .panneau__instructions-code-promo__code-promo__message"; +const DOM_MESSAGE_FORMULAIRE_ADRESSES = "#panneau-informations-client #message-formulaire-adresses"; +const DOM_PRIX_LIGNE_PANIER = ".detail-produit__nom-prix span"; +const DOM_SOUS_TOTAL_LIVRAISON_COUT = "#panneau-panier #sous-total-livraison strong"; +const DOM_SOUS_TOTAL_PRODUITS = "#panneau-panier #sous-total-produits strong"; +const DOM_TOTAL_PANIER = "#panneau-panier .panneau__pied-de-page p span"; +const DOM_TOTAL_REDUCTION = "#panneau-panier #sous-total-reduction"; +const DOM_TOTAL_REDUCTION_VALEUR = "#panneau-panier #sous-total-reduction strong"; +const DOM_CONTENEUR_ANIMATION = ".storytelling__animation"; +const DOM_CONTENEUR_STORYTELLING = ".storytelling"; +const DOM_GARDE_FOU_JS = "no-js"; +const DOM_IMAGES_STORYTELLING = ".storytelling__image"; +const DOM_BOUTON_PLUS_PRODUITS = "#page-boutique #bouton-plus-de-produits"; +const DOM_GRILLE_PRODUITS = "#page-boutique .grille-produits"; +const CLASS_BOITE_TEXTE = "boite-texte"; +const CLASS_BOUTON_FERMETURE_BOITE_TEXTE = "boite-texte__bouton-fermeture"; +const CLASS_EPINGLE = "epingle"; +const DOM_BOITE_TEXTE = `.${CLASS_BOITE_TEXTE}`; +const DOM_BOUTON_FERMETURE_BOITE_TEXTE = `.${CLASS_BOUTON_FERMETURE_BOITE_TEXTE}`; +const DOM_CONTENEUR_STORYTELLING_A_PROPOS = ".storytelling__conteneur"; +const DOM_EPINGLE = `.${CLASS_EPINGLE}`; +const DOM_BOUTON_AJOUT_PANIER = "#bouton-ajout-panier"; +const DOM_CONTENEUR_PANIER = "#page-panier"; +const DOM_PRIX_PRODUIT = ".selecteur-produit__prix"; +const DOM_DOM_QUANTITE = "#selecteur-variation"; +const DOM_BOUTONS_ACCORDEON = ".section-textuelle button"; +const DOM_CONTENUS_ACCORDEON = ".section-textuelle__contenu"; + +//#endregion +//#region node_modules/purify-ts/esm/Maybe.js +const Maybe = { + of(value$1) { + return just(value$1); + }, + empty() { + return nothing; + }, + zero() { + return nothing; + }, + fromNullable(value$1) { + return value$1 == null ? nothing : just(value$1); + }, + fromFalsy(value$1) { + return value$1 ? just(value$1) : nothing; + }, + fromPredicate(pred, value$1) { + switch (arguments.length) { + case 1: return (value$2) => Maybe.fromPredicate(pred, value$2); + default: return pred(value$1) ? just(value$1) : nothing; + } + }, + mapMaybe(f, list) { + switch (arguments.length) { + case 1: return (list$1) => Maybe.mapMaybe(f, list$1); + default: return Maybe.catMaybes(list.map(f)); + } + }, + catMaybes(list) { + let res = []; + for (const e of list) if (e.isJust()) res.push(e.extract()); + return res; + }, + encase(thunk) { + try { + return just(thunk()); + } catch { + return nothing; + } + }, + isMaybe(x) { + return x instanceof Just || x instanceof Nothing; + }, + sequence(maybes) { + let res = []; + for (const m of maybes) if (m.isJust()) res.push(m.extract()); + else return nothing; + return just(res); + }, + "fantasy-land/of"(value$1) { + return this.of(value$1); + }, + "fantasy-land/empty"() { + return this.empty(); + }, + "fantasy-land/zero"() { + return this.zero(); + } +}; +var Just = class { + constructor(__value) { + this.__value = __value; + } + isJust() { + return true; + } + isNothing() { + return false; + } + inspect() { + return `Just(${this.__value})`; + } + [Symbol.for("nodejs.util.inspect.custom")](_depth, opts, inspect) { + return `Just(${inspect(this.__value, opts)})`; + } + toString() { + return this.inspect(); + } + toJSON() { + const value$1 = this.__value; + return value$1 instanceof Date ? value$1.toJSON() : value$1; + } + equals(other) { + return this.extract() === other.extract(); + } + map(f) { + return just(f(this.__value)); + } + ap(maybeF) { + return maybeF.isJust() ? this.map(maybeF.extract()) : nothing; + } + alt(_) { + return this; + } + altLazy(_) { + return this; + } + chain(f) { + return f(this.__value); + } + chainNullable(f) { + return Maybe.fromNullable(f(this.__value)); + } + join() { + return this.__value; + } + reduce(reducer, initialValue) { + return reducer(initialValue, this.__value); + } + extend(f) { + return just(f(this)); + } + unsafeCoerce() { + return this.__value; + } + caseOf(patterns) { + return "_" in patterns ? patterns._() : patterns.Just(this.__value); + } + orDefault(_) { + return this.__value; + } + orDefaultLazy(_) { + return this.__value; + } + toList() { + return [this.__value]; + } + mapOrDefault(f, _) { + return f(this.__value); + } + extract() { + return this.__value; + } + extractNullable() { + return this.__value; + } + toEither(_) { + return right(this.__value); + } + ifJust(effect) { + return effect(this.__value), this; + } + ifNothing(_) { + return this; + } + filter(pred) { + return pred(this.__value) ? just(this.__value) : nothing; + } +}; +Just.prototype["fantasy-land/equals"] = Just.prototype.equals; +Just.prototype["fantasy-land/map"] = Just.prototype.map; +Just.prototype["fantasy-land/ap"] = Just.prototype.ap; +Just.prototype["fantasy-land/alt"] = Just.prototype.alt; +Just.prototype["fantasy-land/chain"] = Just.prototype.chain; +Just.prototype["fantasy-land/reduce"] = Just.prototype.reduce; +Just.prototype["fantasy-land/extend"] = Just.prototype.extend; +Just.prototype["fantasy-land/filter"] = Just.prototype.filter; +Just.prototype.constructor = Maybe; +var Nothing = class { + isJust() { + return false; + } + isNothing() { + return true; + } + inspect() { + return "Nothing"; + } + [Symbol.for("nodejs.util.inspect.custom")]() { + return "Nothing"; + } + toString() { + return this.inspect(); + } + toJSON() { + return this.__value; + } + equals(other) { + return this.extract() === other.extract(); + } + map(_) { + return nothing; + } + ap(_) { + return nothing; + } + alt(other) { + return other; + } + altLazy(other) { + return other(); + } + chain(_) { + return nothing; + } + chainNullable(_) { + return nothing; + } + join() { + return nothing; + } + reduce(_, initialValue) { + return initialValue; + } + extend(_) { + return nothing; + } + unsafeCoerce() { + throw new Error("Maybe#unsafeCoerce was ran on a Nothing"); + } + caseOf(patterns) { + return "_" in patterns ? patterns._() : patterns.Nothing(); + } + orDefault(defaultValue) { + return defaultValue; + } + orDefaultLazy(getDefaultValue) { + return getDefaultValue(); + } + toList() { + return []; + } + mapOrDefault(_, defaultValue) { + return defaultValue; + } + extract() {} + extractNullable() { + return null; + } + toEither(left$1) { + return left(left$1); + } + ifJust(_) { + return this; + } + ifNothing(effect) { + return effect(), this; + } + filter(_) { + return nothing; + } +}; +Nothing.prototype["fantasy-land/equals"] = Nothing.prototype.equals; +Nothing.prototype["fantasy-land/map"] = Nothing.prototype.map; +Nothing.prototype["fantasy-land/ap"] = Nothing.prototype.ap; +Nothing.prototype["fantasy-land/alt"] = Nothing.prototype.alt; +Nothing.prototype["fantasy-land/chain"] = Nothing.prototype.chain; +Nothing.prototype["fantasy-land/reduce"] = Nothing.prototype.reduce; +Nothing.prototype["fantasy-land/extend"] = Nothing.prototype.extend; +Nothing.prototype["fantasy-land/filter"] = Nothing.prototype.filter; +Nothing.prototype.constructor = Maybe; +/** Constructs a Just. Represents an optional value that exists */ +var just = (value$1) => new Just(value$1); +/** Represents a missing value, you can think of it as a smart 'null' */ +var nothing = new Nothing(); + +//#endregion +//#region node_modules/purify-ts/esm/Either.js +const Either = { + of(value$1) { + return right(value$1); + }, + lefts(list) { + let result = []; + for (const x of list) if (x.isLeft()) result.push(x.extract()); + return result; + }, + rights(list) { + let result = []; + for (const x of list) if (x.isRight()) result.push(x.extract()); + return result; + }, + encase(throwsF) { + try { + return right(throwsF()); + } catch (e) { + return left(e); + } + }, + sequence(eithers) { + let res = []; + for (const e of eithers) { + if (e.isLeft()) return e; + res.push(e.extract()); + } + return right(res); + }, + isEither(x) { + return x instanceof Left || x instanceof Right; + }, + "fantasy-land/of"(value$1) { + return Either.of(value$1); + } +}; +var Right = class { + constructor(__value) { + this.__value = __value; + this._ = "R"; + } + isLeft() { + return false; + } + isRight() { + return true; + } + toJSON() { + return this.__value; + } + inspect() { + return `Right(${this.__value})`; + } + [Symbol.for("nodejs.util.inspect.custom")](_depth, opts, inspect) { + return `Right(${inspect(this.__value, opts)})`; + } + toString() { + return this.inspect(); + } + bimap(_, g) { + return right(g(this.__value)); + } + map(f) { + return right(f(this.__value)); + } + mapLeft(_) { + return this; + } + ap(other) { + return other.isRight() ? this.map(other.extract()) : other; + } + equals(other) { + return other.isRight() ? this.__value === other.extract() : false; + } + chain(f) { + return f(this.__value); + } + chainLeft(_) { + return this; + } + join() { + return this.__value; + } + alt(_) { + return this; + } + altLazy(_) { + return this; + } + reduce(reducer, initialValue) { + return reducer(initialValue, this.__value); + } + extend(f) { + return right(f(this)); + } + unsafeCoerce() { + return this.__value; + } + caseOf(patterns) { + return "_" in patterns ? patterns._() : patterns.Right(this.__value); + } + leftOrDefault(defaultValue) { + return defaultValue; + } + orDefault(_) { + return this.__value; + } + orDefaultLazy(_) { + return this.__value; + } + leftOrDefaultLazy(getDefaultValue) { + return getDefaultValue(); + } + ifLeft(_) { + return this; + } + ifRight(effect) { + return effect(this.__value), this; + } + toMaybe() { + return just(this.__value); + } + leftToMaybe() { + return nothing; + } + extract() { + return this.__value; + } + swap() { + return left(this.__value); + } +}; +Right.prototype["fantasy-land/bimap"] = Right.prototype.bimap; +Right.prototype["fantasy-land/map"] = Right.prototype.map; +Right.prototype["fantasy-land/ap"] = Right.prototype.ap; +Right.prototype["fantasy-land/equals"] = Right.prototype.equals; +Right.prototype["fantasy-land/chain"] = Right.prototype.chain; +Right.prototype["fantasy-land/alt"] = Right.prototype.alt; +Right.prototype["fantasy-land/reduce"] = Right.prototype.reduce; +Right.prototype["fantasy-land/extend"] = Right.prototype.extend; +Right.prototype.constructor = Either; +var Left = class { + constructor(__value) { + this.__value = __value; + this._ = "L"; + } + isLeft() { + return true; + } + isRight() { + return false; + } + toJSON() { + return this.__value; + } + inspect() { + return `Left(${JSON.stringify(this.__value)})`; + } + [Symbol.for("nodejs.util.inspect.custom")](_depth, opts, inspect) { + return `Left(${inspect(this.__value, opts)})`; + } + toString() { + return this.inspect(); + } + bimap(f, _) { + return left(f(this.__value)); + } + map(_) { + return this; + } + mapLeft(f) { + return left(f(this.__value)); + } + ap(other) { + return other.isLeft() ? other : this; + } + equals(other) { + return other.isLeft() ? other.extract() === this.__value : false; + } + chain(_) { + return this; + } + chainLeft(f) { + return f(this.__value); + } + join() { + return this; + } + alt(other) { + return other; + } + altLazy(other) { + return other(); + } + reduce(_, initialValue) { + return initialValue; + } + extend(_) { + return this; + } + unsafeCoerce() { + if (this.__value instanceof Error) throw this.__value; + throw new Error("Either#unsafeCoerce was ran on a Left"); + } + caseOf(patterns) { + return "_" in patterns ? patterns._() : patterns.Left(this.__value); + } + leftOrDefault(_) { + return this.__value; + } + orDefault(defaultValue) { + return defaultValue; + } + orDefaultLazy(getDefaultValue) { + return getDefaultValue(); + } + leftOrDefaultLazy(_) { + return this.__value; + } + ifLeft(effect) { + return effect(this.__value), this; + } + ifRight(_) { + return this; + } + toMaybe() { + return nothing; + } + leftToMaybe() { + return just(this.__value); + } + extract() { + return this.__value; + } + swap() { + return right(this.__value); + } +}; +Left.prototype["fantasy-land/bimap"] = Left.prototype.bimap; +Left.prototype["fantasy-land/map"] = Left.prototype.map; +Left.prototype["fantasy-land/ap"] = Left.prototype.ap; +Left.prototype["fantasy-land/equals"] = Left.prototype.equals; +Left.prototype["fantasy-land/chain"] = Left.prototype.chain; +Left.prototype["fantasy-land/alt"] = Left.prototype.alt; +Left.prototype["fantasy-land/reduce"] = Left.prototype.reduce; +Left.prototype["fantasy-land/extend"] = Left.prototype.extend; +Left.prototype.constructor = Either; +var left = (value$1) => new Left(value$1); +var right = (value$1) => new Right(value$1); + +//#endregion +//#region node_modules/purify-ts/esm/Function.js +/** The identity function, returns the value it was given */ +const identity = (x) => x; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/animations.ts +/** +* Créer le nécessaire pour une animation s'exécutant jusqu'à ce que un interval soit manuellement arrêté. L'animation +* consiste en la mise à jour d'un texte avec l'utilisation de toutes les valeurs d'un tableau, une par une. +* +* @param args Les paramètres nécessaires pour la création de l'animation. +* @returns Un objet contenant les informations de l'animation, notamment l'interval utilisable pour son arrêt. +*/ +var lanceAnimationCycleTexte = (args) => { + const animation = { + callback: () => { + if (!args.element.hasAttribute(args.attribut)) { + clearInterval(animation.interval); + return; + } + args.element.textContent = animation.etapes.at(animation.index) ?? "Loading..."; + animation.index = animation.index + 1 > animation.etapes.length - 1 ? 0 : animation.index + 1; + }, + etapes: args.etapes, + index: 0, + interval: setInterval(() => {}, 2147483647) + }; + return animation; +}; +const lanceAnimationCycleLoading = (element, delai) => { + const animation = lanceAnimationCycleTexte({ + attribut: ATTRIBUT_CHARGEMENT, + element, + etapes: [ + "Loading", + "Loading.", + "Loading..", + "Loading..." + ] + }); + animation.callback(); + animation.interval = setInterval(animation.callback, delai); +}; + +//#endregion +//#region node_modules/valibot/dist/index.js +var store; +/* @__NO_SIDE_EFFECTS__ */ +function getGlobalConfig(config2) { + return { + lang: config2?.lang ?? store?.lang, + message: config2?.message, + abortEarly: config2?.abortEarly ?? store?.abortEarly, + abortPipeEarly: config2?.abortPipeEarly ?? store?.abortPipeEarly + }; +} +var store2; +/* @__NO_SIDE_EFFECTS__ */ +function getGlobalMessage(lang) { + return store2?.get(lang); +} +var store3; +/* @__NO_SIDE_EFFECTS__ */ +function getSchemaMessage(lang) { + return store3?.get(lang); +} +var store4; +/* @__NO_SIDE_EFFECTS__ */ +function getSpecificMessage(reference, lang) { + return store4?.get(reference)?.get(lang); +} +/* @__NO_SIDE_EFFECTS__ */ +function _stringify(input) { + const type = typeof input; + if (type === "string") return `"${input}"`; + if (type === "number" || type === "bigint" || type === "boolean") return `${input}`; + if (type === "object" || type === "function") return (input && Object.getPrototypeOf(input)?.constructor?.name) ?? "null"; + return type; +} +function _addIssue(context, label, dataset, config2, other) { + const input = other && "input" in other ? other.input : dataset.value; + const expected = other?.expected ?? context.expects ?? null; + const received = other?.received ?? /* @__PURE__ */ _stringify(input); + const issue = { + kind: context.kind, + type: context.type, + input, + expected, + received, + message: `Invalid ${label}: ${expected ? `Expected ${expected} but r` : "R"}eceived ${received}`, + requirement: context.requirement, + path: other?.path, + issues: other?.issues, + lang: config2.lang, + abortEarly: config2.abortEarly, + abortPipeEarly: config2.abortPipeEarly + }; + const isSchema = context.kind === "schema"; + const message2 = other?.message ?? context.message ?? /* @__PURE__ */ getSpecificMessage(context.reference, issue.lang) ?? (isSchema ? /* @__PURE__ */ getSchemaMessage(issue.lang) : null) ?? config2.message ?? /* @__PURE__ */ getGlobalMessage(issue.lang); + if (message2 !== void 0) issue.message = typeof message2 === "function" ? message2(issue) : message2; + if (isSchema) dataset.typed = false; + if (dataset.issues) dataset.issues.push(issue); + else dataset.issues = [issue]; +} +/* @__NO_SIDE_EFFECTS__ */ +function _getStandardProps(context) { + return { + version: 1, + vendor: "valibot", + validate(value2) { + return context["~run"]({ value: value2 }, /* @__PURE__ */ getGlobalConfig()); + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function _joinExpects(values2, separator) { + const list = [...new Set(values2)]; + if (list.length > 1) return `(${list.join(` ${separator} `)})`; + return list[0] ?? "never"; +} +var ValiError = class extends Error { + /** + * Creates a Valibot error with useful information. + * + * @param issues The error issues. + */ + constructor(issues) { + super(issues[0].message); + this.name = "ValiError"; + this.issues = issues; + } +}; +/* @__NO_SIDE_EFFECTS__ */ +function includes(requirement, message2) { + const expects = /* @__PURE__ */ _stringify(requirement); + return { + kind: "validation", + type: "includes", + reference: includes, + async: false, + expects, + requirement, + message: message2, + "~run"(dataset, config2) { + if (dataset.typed && !dataset.value.includes(this.requirement)) _addIssue(this, "content", dataset, config2, { received: `!${expects}` }); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function integer(message2) { + return { + kind: "validation", + type: "integer", + reference: integer, + async: false, + expects: null, + requirement: Number.isInteger, + message: message2, + "~run"(dataset, config2) { + if (dataset.typed && !this.requirement(dataset.value)) _addIssue(this, "integer", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function maxValue(requirement, message2) { + return { + kind: "validation", + type: "max_value", + reference: maxValue, + async: false, + expects: `<=${requirement instanceof Date ? requirement.toJSON() : /* @__PURE__ */ _stringify(requirement)}`, + requirement, + message: message2, + "~run"(dataset, config2) { + if (dataset.typed && !(dataset.value <= this.requirement)) _addIssue(this, "value", dataset, config2, { received: dataset.value instanceof Date ? dataset.value.toJSON() : /* @__PURE__ */ _stringify(dataset.value) }); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function minValue(requirement, message2) { + return { + kind: "validation", + type: "min_value", + reference: minValue, + async: false, + expects: `>=${requirement instanceof Date ? requirement.toJSON() : /* @__PURE__ */ _stringify(requirement)}`, + requirement, + message: message2, + "~run"(dataset, config2) { + if (dataset.typed && !(dataset.value >= this.requirement)) _addIssue(this, "value", dataset, config2, { received: dataset.value instanceof Date ? dataset.value.toJSON() : /* @__PURE__ */ _stringify(dataset.value) }); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function transform(operation) { + return { + kind: "transformation", + type: "transform", + reference: transform, + async: false, + operation, + "~run"(dataset) { + dataset.value = this.operation(dataset.value); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function url(message2) { + return { + kind: "validation", + type: "url", + reference: url, + async: false, + expects: null, + requirement(input) { + try { + new URL(input); + return true; + } catch { + return false; + } + }, + message: message2, + "~run"(dataset, config2) { + if (dataset.typed && !this.requirement(dataset.value)) _addIssue(this, "URL", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function value(requirement, message2) { + return { + kind: "validation", + type: "value", + reference: value, + async: false, + expects: requirement instanceof Date ? requirement.toJSON() : /* @__PURE__ */ _stringify(requirement), + requirement, + message: message2, + "~run"(dataset, config2) { + if (dataset.typed && !(this.requirement <= dataset.value && this.requirement >= dataset.value)) _addIssue(this, "value", dataset, config2, { received: dataset.value instanceof Date ? dataset.value.toJSON() : /* @__PURE__ */ _stringify(dataset.value) }); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function getFallback(schema, dataset, config2) { + return typeof schema.fallback === "function" ? schema.fallback(dataset, config2) : schema.fallback; +} +/* @__NO_SIDE_EFFECTS__ */ +function getDefault(schema, dataset, config2) { + return typeof schema.default === "function" ? schema.default(dataset, config2) : schema.default; +} +/* @__NO_SIDE_EFFECTS__ */ +function is(schema, input) { + return !schema["~run"]({ value: input }, { abortEarly: true }).issues; +} +/* @__NO_SIDE_EFFECTS__ */ +function array(item, message2) { + return { + kind: "schema", + type: "array", + reference: array, + expects: "Array", + async: false, + item, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + const input = dataset.value; + if (Array.isArray(input)) { + dataset.typed = true; + dataset.value = []; + for (let key = 0; key < input.length; key++) { + const value2 = input[key]; + const itemDataset = this.item["~run"]({ value: value2 }, config2); + if (itemDataset.issues) { + const pathItem = { + type: "array", + origin: "value", + input, + key, + value: value2 + }; + for (const issue of itemDataset.issues) { + if (issue.path) issue.path.unshift(pathItem); + else issue.path = [pathItem]; + dataset.issues?.push(issue); + } + if (!dataset.issues) dataset.issues = itemDataset.issues; + if (config2.abortEarly) { + dataset.typed = false; + break; + } + } + if (!itemDataset.typed) dataset.typed = false; + dataset.value.push(itemDataset.value); + } + } else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function boolean(message2) { + return { + kind: "schema", + type: "boolean", + reference: boolean, + expects: "boolean", + async: false, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + if (typeof dataset.value === "boolean") dataset.typed = true; + else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function enum_(enum__, message2) { + const options = []; + for (const key in enum__) if (`${+key}` !== key || typeof enum__[key] !== "string" || !Object.is(enum__[enum__[key]], +key)) options.push(enum__[key]); + return { + kind: "schema", + type: "enum", + reference: enum_, + expects: /* @__PURE__ */ _joinExpects(options.map(_stringify), "|"), + async: false, + enum: enum__, + options, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + if (this.options.includes(dataset.value)) dataset.typed = true; + else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function literal(literal_, message2) { + return { + kind: "schema", + type: "literal", + reference: literal, + expects: /* @__PURE__ */ _stringify(literal_), + async: false, + literal: literal_, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + if (dataset.value === this.literal) dataset.typed = true; + else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function null_(message2) { + return { + kind: "schema", + type: "null", + reference: null_, + expects: "null", + async: false, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + if (dataset.value === null) dataset.typed = true; + else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function number(message2) { + return { + kind: "schema", + type: "number", + reference: number, + expects: "number", + async: false, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + if (typeof dataset.value === "number" && !isNaN(dataset.value)) dataset.typed = true; + else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function object(entries2, message2) { + return { + kind: "schema", + type: "object", + reference: object, + expects: "Object", + async: false, + entries: entries2, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + const input = dataset.value; + if (input && typeof input === "object") { + dataset.typed = true; + dataset.value = {}; + for (const key in this.entries) { + const valueSchema = this.entries[key]; + if (key in input || (valueSchema.type === "exact_optional" || valueSchema.type === "optional" || valueSchema.type === "nullish") && valueSchema.default !== void 0) { + const value2 = key in input ? input[key] : /* @__PURE__ */ getDefault(valueSchema); + const valueDataset = valueSchema["~run"]({ value: value2 }, config2); + if (valueDataset.issues) { + const pathItem = { + type: "object", + origin: "value", + input, + key, + value: value2 + }; + for (const issue of valueDataset.issues) { + if (issue.path) issue.path.unshift(pathItem); + else issue.path = [pathItem]; + dataset.issues?.push(issue); + } + if (!dataset.issues) dataset.issues = valueDataset.issues; + if (config2.abortEarly) { + dataset.typed = false; + break; + } + } + if (!valueDataset.typed) dataset.typed = false; + dataset.value[key] = valueDataset.value; + } else if (valueSchema.fallback !== void 0) dataset.value[key] = /* @__PURE__ */ getFallback(valueSchema); + else if (valueSchema.type !== "exact_optional" && valueSchema.type !== "optional" && valueSchema.type !== "nullish") { + _addIssue(this, "key", dataset, config2, { + input: void 0, + expected: `"${key}"`, + path: [{ + type: "object", + origin: "key", + input, + key, + value: input[key] + }] + }); + if (config2.abortEarly) break; + } + } + } else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function optional(wrapped, default_) { + return { + kind: "schema", + type: "optional", + reference: optional, + expects: `(${wrapped.expects} | undefined)`, + async: false, + wrapped, + default: default_, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + if (dataset.value === void 0) { + if (this.default !== void 0) dataset.value = /* @__PURE__ */ getDefault(this, dataset, config2); + if (dataset.value === void 0) { + dataset.typed = true; + return dataset; + } + } + return this.wrapped["~run"](dataset, config2); + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function string(message2) { + return { + kind: "schema", + type: "string", + reference: string, + expects: "string", + async: false, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + if (typeof dataset.value === "string") dataset.typed = true; + else _addIssue(this, "type", dataset, config2); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function _subIssues(datasets) { + let issues; + if (datasets) for (const dataset of datasets) if (issues) issues.push(...dataset.issues); + else issues = dataset.issues; + return issues; +} +/* @__NO_SIDE_EFFECTS__ */ +function union(options, message2) { + return { + kind: "schema", + type: "union", + reference: union, + expects: /* @__PURE__ */ _joinExpects(options.map((option) => option.expects), "|"), + async: false, + options, + message: message2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + let validDataset; + let typedDatasets; + let untypedDatasets; + for (const schema of this.options) { + const optionDataset = schema["~run"]({ value: dataset.value }, config2); + if (optionDataset.typed) if (optionDataset.issues) if (typedDatasets) typedDatasets.push(optionDataset); + else typedDatasets = [optionDataset]; + else { + validDataset = optionDataset; + break; + } + else if (untypedDatasets) untypedDatasets.push(optionDataset); + else untypedDatasets = [optionDataset]; + } + if (validDataset) return validDataset; + if (typedDatasets) { + if (typedDatasets.length === 1) return typedDatasets[0]; + _addIssue(this, "type", dataset, config2, { issues: /* @__PURE__ */ _subIssues(typedDatasets) }); + dataset.typed = true; + } else if (untypedDatasets?.length === 1) return untypedDatasets[0]; + else _addIssue(this, "type", dataset, config2, { issues: /* @__PURE__ */ _subIssues(untypedDatasets) }); + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function unknown() { + return { + kind: "schema", + type: "unknown", + reference: unknown, + expects: "unknown", + async: false, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset) { + dataset.typed = true; + return dataset; + } + }; +} +/* @__NO_SIDE_EFFECTS__ */ +function omit(schema, keys) { + const entries2 = { ...schema.entries }; + for (const key of keys) delete entries2[key]; + return { + ...schema, + entries: entries2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + } + }; +} +function parse(schema, input, config2) { + const dataset = schema["~run"]({ value: input }, /* @__PURE__ */ getGlobalConfig(config2)); + if (dataset.issues) throw new ValiError(dataset.issues); + return dataset.value; +} +/* @__NO_SIDE_EFFECTS__ */ +function pipe$1(...pipe2) { + return { + ...pipe2[0], + pipe: pipe2, + get "~standard"() { + return /* @__PURE__ */ _getStandardProps(this); + }, + "~run"(dataset, config2) { + for (const item of pipe2) if (item.kind !== "metadata") { + if (dataset.issues && (item.kind === "schema" || item.kind === "transformation")) { + dataset.typed = false; + break; + } + if (!dataset.issues || !config2.abortEarly && !config2.abortPipeEarly) dataset = item["~run"](dataset, config2); + } + return dataset; + } + }; +} + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/erreurs/adresses.ts +/** Types d'Erreurs liées aux adresses WooCommerce. */ +var ErreurAdresseInvalide = class extends Error { + constructor(problemes) { + super("Le ou les adresses fournies sont invalides."); + _defineProperty(this, "problemes", void 0); + this.name = "ErreurAdresseInvalide"; + this.problemes = problemes; + } +}; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/erreurs.ts +const ERREUR_SYNTAXE_INVALIDE = (selecteur) => `Le selecteur "${selecteur}" est invalide`; +const ERREUR_DOM_INEXISTANT = (selecteur) => `La requête "${selecteur}" n'a retourné aucun Élément.`; +const creeSyntaxError = (message) => new SyntaxError(message); +var BadRequestError = class extends Error { + constructor(message = "400 BadRequestError") { + super(message); + this.name = "BadRequestError"; + } +}; +var CleNonTrouveError = class extends Error { + constructor(message) { + super(JSON.stringify(message)); + this.name = "CleNonTrouveError"; + } +}; +var ForbiddenError = class extends Error { + constructor(message = "403 ForbiddenError") { + super(message); + this.name = "ForbiddenError"; + } +}; +var NonExistingKeyError = class extends Error { + constructor(message) { + super(JSON.stringify(message)); + this.name = "NonExistingKeyError"; + } +}; +var NotFoundError = class extends Error { + constructor(message = "404 NotFoundError") { + super(message); + this.name = "NotFoundError"; + } +}; +var ServerError = class extends Error { + constructor(message = "500 ServerError") { + super(message); + this.name = "ServerError"; + } +}; +var UnauthorizedError = class extends Error { + constructor(message = "401 UnauthorizedError") { + super(message); + this.name = "UnauthorizedError"; + } +}; +const ErreurEntreeInexistante = (message) => new NonExistingKeyError(message); +/** +* Reporte une Erreur, sous forme d'erreur console et au service GlitchTip. +* +* @param erreur +* @returns L'ID Sentry de l'évènement capturé. +*/ +const reporteErreur = (erreur) => captureException(erreur); +/** +* Reporte une Erreur, sous forme d'erreur console et au service GlitchTip, puis la lève sous forme +* d'Exception. +* +* @param erreur +* @returns never Lève une Erreur et ne retourne donc rien. +*/ +const reporteEtLeveErreur = (erreur) => { + reporteErreur(erreur); + throw erreur; +}; +const reporteEtJournaliseErreur = (erreur) => { + reporteErreur(erreur); + console.error(erreur); + if (erreur instanceof ValiError) console.error(erreur.issues); + if (erreur instanceof ErreurAdresseInvalide) console.error(erreur.problemes); +}; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/dom.ts +const recupereElementAvecSelecteur = (parent) => (selecteur) => Either.encase(() => parent.querySelector(selecteur)).mapLeft((_) => creeSyntaxError(ERREUR_SYNTAXE_INVALIDE(selecteur))).chain((e) => i.isNotNullable(e) ? right(e) : left(creeSyntaxError(ERREUR_DOM_INEXISTANT(selecteur)))); +const getDOMElementsWithSelector = (parent) => (selecteur) => Either.encase(() => pipe(parent.querySelectorAll(selecteur), Array.from)).mapLeft((_) => creeSyntaxError(ERREUR_SYNTAXE_INVALIDE(selecteur))).chain((e) => Ra.isEmpty(e) ? left(creeSyntaxError(ERREUR_DOM_INEXISTANT(selecteur))) : right(e)); +const recupereElementOuLeve = (elementOuErreur) => elementOuErreur.caseOf({ + Left: reporteEtLeveErreur, + Right: identity +}); +const recupereElementsOuLeve = (elementsOuErreur) => elementsOuErreur.caseOf({ + Left: reporteEtLeveErreur, + Right: identity +}); +const majElementInnerHtml = (element) => (innerHtml) => { + element.innerHTML = innerHtml; + return element; +}; +const html = (strings, ...args) => pipe(document.createElement("template"), (template) => majElementInnerHtml(template)(args.reduce((prev, value$1, i$1) => prev + value$1 + strings[i$1 + 1], strings[0])), (template) => template.content); +/** +* Convertis une chaîne JSON en un objet JavaScript sous forme d'`Either`. +* @param chaine La chaîne à convertir. +* @returns Un `Either` avec une `SyntaxError` si la chaîne est invalide, un objet JS sinon +* (`Right`). +*/ +const safeJsonParse = (chaine) => Either.encase(() => JSON.parse(chaine)); +/** +* Vérifie qu'un sélecteur s'applique à l'élément DOM d'une cible d'événement (un `EventTarget`) donnée. +* La fonction agit comme un garde de type. +* +* @returns Un booléen +*/ +const targetMatchesSelector = (cible, selecteur) => cible !== null && cible.matches(selecteur); +const recupereElementsDocumentEither = getDOMElementsWithSelector(document); +const recupereElementDocumentEither = recupereElementAvecSelecteur(document); +/** +* Fonction utilitaire pour récupérer un Élément selon un sélecteur au sein du Document. +* +* @param selecteur Le sélecteur de l'Élément recherché. +* @throws Une SyntaxError si l'Élément n'est pas trouvé. +* @returns Un Élément. +*/ +const mustGetEleInDocument = (selecteur) => pipe(recupereElementDocumentEither(selecteur), recupereElementOuLeve); +const mustGetEleInParent = (parent) => (selector) => pipe(recupereElementAvecSelecteur(parent)(selector), recupereElementOuLeve); +/** +* Fonction utilitaire pour récupérer des Éléments selon un sélecteur au sein du Document. +* +* @param selecteur Le sélecteur des Éléments recherchés. +* @throws Une SyntaxError si aucun Élément n'est trouvé. +* @returns Un tableau d'Éléments. +*/ +const mustGetElesInDocument = (selecteur) => pipe(recupereElementsDocumentEither(selecteur), recupereElementsOuLeve); +const setButtonLoadingState = (button, isLoading) => { + logger.debug("majEtatChargementBouton", button, isLoading); + if (isLoading) { + button.setAttribute(ATTRIBUT_DESACTIVE, ""); + button.setAttribute(ATTRIBUT_CHARGEMENT, ""); + lanceAnimationCycleLoading(button, 500); + } else { + button.removeAttribute(ATTRIBUT_CHARGEMENT); + button.removeAttribute(ATTRIBUT_DESACTIVE); + } +}; +const estErreurHttp = (erreur) => erreur instanceof BadRequestError || erreur instanceof ForbiddenError || erreur instanceof NotFoundError || erreur instanceof ServerError || erreur instanceof UnauthorizedError; +const estErreurFetch = (erreur) => erreur instanceof DOMException || erreur instanceof TypeError || erreur instanceof Error; + +//#endregion +export { Maybe as $, DOM_INSTRUCTIONS_CLIENT as $t, integer as A, DOM_BOUTON_PANIER as At, parse as B, DOM_CONTENEUR_STORYTELLING as Bt, reporteEtJournaliseErreur as C, mapU as Cn, DOM_BOITE_TEXTE as Ct, boolean as D, valFromOption as Dn, DOM_BOUTON_AJOUT_PANIER as Dt, array as E, some$1 as En, DOM_BOUTON_ADDITION_QUANTITE as Et, null_ as F, DOM_CHAMP_CODE_PROMO as Ft, unknown as G, DOM_ENTREES_PANIER as Gt, string as H, DOM_CONTENUS_ACCORDEON as Ht, number as I, DOM_CHAMP_QUANTITE_LIGNE_PANIER as It, lanceAnimationCycleLoading as J, DOM_FORMULAIRE_FACTURATION as Jt, url as K, DOM_ENTREE_MENU_CATEGORIES_PRODUITS as Kt, object as L, DOM_CONTENEUR_ANIMATION as Lt, literal as M, DOM_BOUTON_SEPARATION_ADRESSES as Mt, maxValue as N, DOM_BOUTON_SOUSTRACTION_QUANTITE as Nt, enum_ as O, equal as On, DOM_BOUTON_CODE_PROMO as Ot, minValue as P, DOM_BOUTON_SUPPRESSION_PANIER as Pt, right as Q, DOM_IMAGES_STORYTELLING as Qt, omit as R, DOM_CONTENEUR_METHODES_LIVRAISON as Rt, reporteErreur as S, forEachU as Sn, CLASS_EPINGLE as St, ValiError as T, nullable_to_opt as Tn, DOM_BOUTON_ACTIONS_FORMULAIRE as Tt, transform as U, DOM_DOM_QUANTITE as Ut, pipe$1 as V, DOM_CONTENEUR_STORYTELLING_A_PROPOS as Vt, union as W, DOM_ENSEMBLE_CODE_PROMO as Wt, Either as X, DOM_GARDE_FOU_JS as Xt, identity as Y, DOM_FORMULAIRE_PANIER as Yt, left as Z, DOM_GRILLE_PRODUITS as Zt, ErreurEntreeInexistante as _, head as _n, ATTRIBUT_MENU_MOBILE_ACTIVE as _t, mustGetEleInDocument as a, DOM_PRIX_PRODUIT as an, ATTRIBUT_ARIA_HIDDEN as at, ServerError as b, values as bn, ATTRIBUT_TABINDEX as bt, recupereElementAvecSelecteur as c, DOM_TOTAL_PANIER as cn, ATTRIBUT_CLE_PANIER as ct, recupereElementsDocumentEither as d, Ra as dn, ATTRIBUT_DESACTIVE as dt, DOM_MENU_CATEGORIES_PRODUITS as en, just as et, safeJsonParse as f, append as fn, ATTRIBUT_ENSEMBLE_EPINGLE_BOITE_ACTIF as ft, CleNonTrouveError as g, get$1$1 as gn, ATTRIBUT_LIVRAISON_VALIDEE as gt, BadRequestError as h, fromArray as hn, ATTRIBUT_ID_ENSEMBLE_EPINGLE_BOITE as ht, html as i, DOM_PRIX_LIGNE_PANIER as in, ATTRIBUT_ARIA_EXPANDED as it, is as j, DOM_BOUTON_PLUS_PRODUITS as jt, includes as k, DOM_BOUTON_MENU_MOBILE as kt, recupereElementDocumentEither as l, DOM_TOTAL_REDUCTION as ln, ATTRIBUT_CODE_PROMO_PRESENT as lt, targetMatchesSelector as m, forEach as mn, ATTRIBUT_ID_CATEGORIE_PRODUITS as mt, estErreurHttp as n, DOM_MESSAGE_CODE_PROMO as nn, ATTRIBUT_ACTIF as nt, mustGetEleInParent as o, DOM_SOUS_TOTAL_LIVRAISON_COUT as on, ATTRIBUT_CACHÉ as ot, setButtonLoadingState as p, find as pn, ATTRIBUT_HIDDEN as pt, value as q, DOM_EPINGLE as qt, getDOMElementsWithSelector as r, DOM_MESSAGE_FORMULAIRE_ADRESSES as rn, ATTRIBUT_ARIA_CONTROLS as rt, mustGetElesInDocument as s, DOM_SOUS_TOTAL_PRODUITS as sn, ATTRIBUT_CHARGEMENT as st, estErreurFetch as t, DOM_MENU_MOBILE as tn, nothing as tt, recupereElementOuLeve as u, DOM_TOTAL_REDUCTION_VALEUR as un, ATTRIBUT_CONTIENT_ARTICLES as ut, ForbiddenError as v, map as vn, ATTRIBUT_PAGE as vt, ErreurAdresseInvalide as w, reduceU as wn, DOM_BOUTONS_ACCORDEON as wt, UnauthorizedError as x, concat$1 as xn, CLASS_BOUTON_FERMETURE_BOITE_TEXTE as xt, NotFoundError as y, unsafeDeleteKey as yn, ATTRIBUT_PRIX as yt, optional as z, DOM_CONTENEUR_PANIER as zt }; +//# sourceMappingURL=dom.emspS_OW.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js.map b/web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js.map new file mode 100644 index 00000000..86b99401 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/dom.emspS_OW.js.map @@ -0,0 +1 @@ +{"version":3,"file":"dom.emspS_OW.js","names":["i","n","e","r","N","t","a","some","get","n","r","make","range","rangeBy","zip","concat","i","slice","sliceToEnd","a","e","i","r","n","t","get$1","v","g","e","_","l","h","u","d","f","a","y","m","A","o","x","c","B","W","E","k","I","j","w","s","b","q","F","T","includes","M","U","union","p","a","s","e","t","i","r","p","n","l","o","d","c","y","m","f","h","u","x","E","W","g","k","v","A","I","B","j","z","q","M","_","F","T","b","w","O","U","C","N","R","D","G","H","J","K","L","P","Q","S","V","X","Y","Z","$","aa","sa","ea","ta","ia","ra","pa","na","la","oa","da","ca","ya","ma","fa","ha","ua","xa","Ea","Wa","ga","ka","va","Aa","Ia","Ba","ja","za","qa","Ma","_a","Fa","Ta","ba","wa","Oa","Ua","Ca","Na","i","is","value","list","Right","Left","left","value","Just","Nothing","animation: AnimationCycleTexte","pipe","recupereElementsDocumentEither: (\n selecteur: string,\n) => Either>","recupereElementDocumentEither: (\n selecteur: string,\n) => Either"],"sources":["../../../../../../node_modules/@mobily/ts-belt/dist/caml-aa4fccd9.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/caml_obj-c29533cc.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/caml_option-16487d6d.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/belt_Array-b9ebcaa6.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/Array.bs-4b4ec77c.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/index-69bc96f0.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/index-e7228f55.mjs","../../src/scripts/constantes/dom.ts","../../../../../../node_modules/purify-ts/esm/Maybe.js","../../../../../../node_modules/purify-ts/esm/Either.js","../../../../../../node_modules/purify-ts/esm/Function.js","../../src/scripts/lib/animations.ts","../../../../../../node_modules/valibot/dist/index.js","../../src/scripts/lib/erreurs/adresses.ts","../../src/scripts/lib/erreurs.ts","../../src/scripts/lib/dom.ts"],"sourcesContent":["function int_compare(e, r) {\n if (e < r) {\n return -1;\n } else if (e === r) {\n return 0;\n } else {\n return 1;\n }\n}\n\nfunction bool_compare(e, r) {\n if (e) {\n if (r) {\n return 0;\n } else {\n return 1;\n }\n } else if (r) {\n return -1;\n } else {\n return 0;\n }\n}\n\nfunction string_compare(e, r) {\n if (e === r) {\n return 0;\n } else if (e < r) {\n return -1;\n } else {\n return 1;\n }\n}\n\nfunction int_max(e, r) {\n if (e > r) {\n return e;\n } else {\n return r;\n }\n}\n\nexport { int_max as a, bool_compare as b, int_compare as i, string_compare as s };\n","import { s as r, i as e, b as n } from \"./caml-aa4fccd9.mjs\";\n\nvar for_in = function(r, e) {\n for (var n in r) {\n e(n);\n }\n};\n\nfunction compare(t, a) {\n if (t === a) {\n return 0;\n }\n var i = typeof t;\n var u = typeof a;\n switch (i) {\n case \"boolean\":\n if (\"boolean\" === u) {\n return n(t, a);\n }\n break;\n\n case \"function\":\n if (\"function\" === u) {\n throw {\n RE_EXN_ID: \"Invalid_argument\",\n _1: \"compare: functional value\",\n Error: new Error\n };\n }\n break;\n\n case \"number\":\n if (\"number\" === u) {\n return e(t, a);\n }\n break;\n\n case \"string\":\n if (\"string\" === u) {\n return r(t, a);\n } else {\n return 1;\n }\n\n case \"undefined\":\n return -1;\n }\n switch (u) {\n case \"string\":\n return -1;\n\n case \"undefined\":\n return 1;\n\n default:\n if (\"boolean\" === i) {\n return 1;\n }\n if (\"boolean\" === u) {\n return -1;\n }\n if (\"function\" === i) {\n return 1;\n }\n if (\"function\" === u) {\n return -1;\n }\n if (\"number\" === i) {\n if (null === a || void 0 !== a.BS_PRIVATE_NESTED_SOME_NONE) {\n return 1;\n } else {\n return -1;\n }\n }\n if (\"number\" === u) {\n if (null === t || void 0 !== t.BS_PRIVATE_NESTED_SOME_NONE) {\n return -1;\n } else {\n return 1;\n }\n }\n if (null === t) {\n if (void 0 !== a.BS_PRIVATE_NESTED_SOME_NONE) {\n return 1;\n } else {\n return -1;\n }\n }\n if (null === a) {\n if (void 0 !== t.BS_PRIVATE_NESTED_SOME_NONE) {\n return -1;\n } else {\n return 1;\n }\n }\n if (void 0 !== t.BS_PRIVATE_NESTED_SOME_NONE) {\n if (void 0 !== a.BS_PRIVATE_NESTED_SOME_NONE) {\n return aux_obj_compare(t, a);\n } else {\n return -1;\n }\n }\n var o = 0 | t.TAG;\n var f = 0 | a.TAG;\n if (248 === o) {\n return e(t[1], a[1]);\n }\n if (251 === o) {\n throw {\n RE_EXN_ID: \"Invalid_argument\",\n _1: \"equal: abstract value\",\n Error: new Error\n };\n }\n if (o !== f) {\n if (o < f) {\n return -1;\n } else {\n return 1;\n }\n }\n var l = 0 | t.length;\n var s = 0 | a.length;\n if (l === s) {\n if (Array.isArray(t)) {\n var c = 0;\n while (1) {\n var v = c;\n if (v === l) {\n return 0;\n }\n var E = compare(t[v], a[v]);\n if (0 !== E) {\n return E;\n }\n c = v + 1 | 0;\n }\n } else if (t instanceof Date && a instanceof Date) {\n return t - a;\n } else {\n return aux_obj_compare(t, a);\n }\n } else if (l < s) {\n var _ = 0;\n while (1) {\n var d = _;\n if (d === l) {\n return -1;\n }\n var p = compare(t[d], a[d]);\n if (0 !== p) {\n return p;\n }\n _ = d + 1 | 0;\n }\n } else {\n var m = 0;\n while (1) {\n var b = m;\n if (b === s) {\n return 1;\n }\n var N = compare(t[b], a[b]);\n if (0 !== N) {\n return N;\n }\n m = b + 1 | 0;\n }\n }\n }\n}\n\nfunction aux_obj_compare(e, n) {\n var t = {\n contents: void 0\n };\n var a = {\n contents: void 0\n };\n var do_key = function(r, e) {\n var n = r[2];\n var t = r[1];\n if (Object.prototype.hasOwnProperty.call(t, e) && !(compare(r[0][e], t[e]) > 0)) {\n return;\n }\n var a = n.contents;\n if (void 0 !== a && e >= a) {\n return;\n } else {\n n.contents = e;\n return;\n }\n };\n var i = [ e, n, a ];\n var u = [ n, e, t ];\n for_in(e, (function(r) {\n return do_key(i, r);\n }));\n for_in(n, (function(r) {\n return do_key(u, r);\n }));\n var o = t.contents;\n var f = a.contents;\n if (void 0 !== o) {\n if (void 0 !== f) {\n return r(o, f);\n } else {\n return -1;\n }\n } else if (void 0 !== f) {\n return 1;\n } else {\n return 0;\n }\n}\n\nfunction equal(r, e) {\n if (r === e) {\n return !0;\n }\n var n = typeof r;\n if (\"string\" === n || \"number\" === n || \"boolean\" === n || \"undefined\" === n || null === r) {\n return !1;\n }\n var t = typeof e;\n if (\"function\" === n || \"function\" === t) {\n throw {\n RE_EXN_ID: \"Invalid_argument\",\n _1: \"equal: functional value\",\n Error: new Error\n };\n }\n if (\"number\" === t || \"undefined\" === t || null === e) {\n return !1;\n }\n var a = 0 | r.TAG;\n var i = 0 | e.TAG;\n if (248 === a) {\n return r[1] === e[1];\n }\n if (251 === a) {\n throw {\n RE_EXN_ID: \"Invalid_argument\",\n _1: \"equal: abstract value\",\n Error: new Error\n };\n }\n if (a !== i) {\n return !1;\n }\n var u = 0 | r.length;\n if (u === (0 | e.length)) {\n if (Array.isArray(r)) {\n var o = 0;\n while (1) {\n var f = o;\n if (f === u) {\n return !0;\n }\n if (!equal(r[f], e[f])) {\n return !1;\n }\n o = f + 1 | 0;\n }\n } else if (r instanceof Date && e instanceof Date) {\n return !(r > e || r < e);\n } else {\n var l = {\n contents: !0\n };\n for_in(r, (function(r) {\n if (!Object.prototype.hasOwnProperty.call(e, r)) {\n l.contents = !1;\n return;\n }\n }));\n if (l.contents) {\n for_in(e, (function(n) {\n if (!Object.prototype.hasOwnProperty.call(r, n) || !equal(e[n], r[n])) {\n l.contents = !1;\n return;\n }\n }));\n }\n return l.contents;\n }\n } else {\n return !1;\n }\n}\n\nfunction lessthan(r, e) {\n return compare(r, e) < 0;\n}\n\nexport { equal as e, lessthan as l };\n","function some(_) {\n if (void 0 === _) {\n return {\n BS_PRIVATE_NESTED_SOME_NONE: 0\n };\n } else if (null !== _ && void 0 !== _.BS_PRIVATE_NESTED_SOME_NONE) {\n return {\n BS_PRIVATE_NESTED_SOME_NONE: _.BS_PRIVATE_NESTED_SOME_NONE + 1 | 0\n };\n } else {\n return _;\n }\n}\n\nfunction nullable_to_opt(_) {\n if (null == _) {\n return;\n } else {\n return some(_);\n }\n}\n\nfunction undefined_to_opt(_) {\n if (void 0 === _) {\n return;\n } else {\n return some(_);\n }\n}\n\nfunction null_to_opt(_) {\n if (null === _) {\n return;\n } else {\n return some(_);\n }\n}\n\nfunction valFromOption(_) {\n if (null === _ || void 0 === _.BS_PRIVATE_NESTED_SOME_NONE) {\n return _;\n }\n var n = _.BS_PRIVATE_NESTED_SOME_NONE;\n if (0 === n) {\n return;\n } else {\n return {\n BS_PRIVATE_NESTED_SOME_NONE: n - 1 | 0\n };\n }\n}\n\nexport { null_to_opt as a, nullable_to_opt as n, some as s, undefined_to_opt as u, valFromOption as v };\n","import { a as r } from \"./caml-aa4fccd9.mjs\";\n\nimport { s as n, v as a } from \"./caml_option-16487d6d.mjs\";\n\nfunction floor_int(r) {\n if (r > 2147483647) {\n return 2147483647;\n } else if (r < -2147483648) {\n return -2147483648;\n } else {\n return Math.floor(r);\n }\n}\n\nfunction random_int(r, n) {\n return floor_int(Math.random() * (n - r | 0)) + r | 0;\n}\n\nfunction get(r, a) {\n if (a >= 0 && a < r.length) {\n return n(r[a]);\n }\n}\n\nfunction getExn(r, n) {\n if (!(n >= 0 && n < r.length)) {\n throw {\n RE_EXN_ID: \"Assert_failure\",\n _1: [ \"belt_Array.ml\", 35, 2 ],\n Error: new Error\n };\n }\n return r[n];\n}\n\nfunction swapUnsafe(r, n, a) {\n var e = r[n];\n r[n] = r[a];\n r[a] = e;\n}\n\nfunction shuffle(r) {\n var n = r.slice(0);\n !function shuffleInPlace(r) {\n var n = r.length;\n for (var a = 0; a < n; ++a) {\n swapUnsafe(r, a, random_int(a, n));\n }\n }(n);\n return n;\n}\n\nfunction reverse(r) {\n var n = r.length;\n var a = new Array(n);\n for (var e = 0; e < n; ++e) {\n a[e] = r[(n - 1 | 0) - e | 0];\n }\n return a;\n}\n\nfunction make(r, n) {\n if (r <= 0) {\n return [];\n }\n var a = new Array(r);\n for (var e = 0; e < r; ++e) {\n a[e] = n;\n }\n return a;\n}\n\nfunction makeByU(r, n) {\n if (r <= 0) {\n return [];\n }\n var a = new Array(r);\n for (var e = 0; e < r; ++e) {\n a[e] = n(e);\n }\n return a;\n}\n\nfunction range(r, n) {\n var a = n - r | 0;\n if (a < 0) {\n return [];\n }\n var e = new Array(a + 1 | 0);\n for (var t = 0; t <= a; ++t) {\n e[t] = r + t | 0;\n }\n return e;\n}\n\nfunction rangeBy(r, n, a) {\n var e = n - r | 0;\n if (e < 0 || a <= 0) {\n return [];\n }\n var t = 1 + (e / a | 0) | 0;\n var v = new Array(t);\n var f = r;\n for (var o = 0; o < t; ++o) {\n v[o] = f;\n f = f + a | 0;\n }\n return v;\n}\n\nfunction zip(r, n) {\n var a = r.length;\n var e = n.length;\n var t = a < e ? a : e;\n var v = new Array(t);\n for (var f = 0; f < t; ++f) {\n v[f] = [ r[f], n[f] ];\n }\n return v;\n}\n\nfunction zipByU(r, n, a) {\n var e = r.length;\n var t = n.length;\n var v = e < t ? e : t;\n var f = new Array(v);\n for (var o = 0; o < v; ++o) {\n f[o] = a(r[o], n[o]);\n }\n return f;\n}\n\nfunction concat(r, n) {\n var a = r.length;\n var e = n.length;\n var t = new Array(a + e | 0);\n for (var v = 0; v < a; ++v) {\n t[v] = r[v];\n }\n for (var f = 0; f < e; ++f) {\n t[a + f | 0] = n[f];\n }\n return t;\n}\n\nfunction concatMany(r) {\n var n = r.length;\n var a = 0;\n for (var e = 0; e < n; ++e) {\n a = a + r[e].length | 0;\n }\n var t = new Array(a);\n a = 0;\n for (var v = 0; v < n; ++v) {\n var f = r[v];\n for (var o = 0, i = f.length; o < i; ++o) {\n t[a] = f[o];\n a = a + 1 | 0;\n }\n }\n return t;\n}\n\nfunction slice(n, a, e) {\n if (e <= 0) {\n return [];\n }\n var t = n.length;\n var v = a < 0 ? r(t + a | 0, 0) : a;\n var f = t - v | 0;\n var o = f < e ? f : e;\n if (o <= 0) {\n return [];\n }\n var i = new Array(o);\n for (var u = 0; u < o; ++u) {\n i[u] = n[v + u | 0];\n }\n return i;\n}\n\nfunction sliceToEnd(n, a) {\n var e = n.length;\n var t = a < 0 ? r(e + a | 0, 0) : a;\n var v = e > t ? e - t | 0 : 0;\n var f = new Array(v);\n for (var o = 0; o < v; ++o) {\n f[o] = n[t + o | 0];\n }\n return f;\n}\n\nfunction blitUnsafe(r, n, a, e, t) {\n if (e <= n) {\n for (var v = 0; v < t; ++v) {\n a[v + e | 0] = r[v + n | 0];\n }\n return;\n }\n for (var f = t - 1 | 0; f >= 0; --f) {\n a[f + e | 0] = r[f + n | 0];\n }\n}\n\nfunction forEachU(r, n) {\n for (var a = 0, e = r.length; a < e; ++a) {\n n(r[a]);\n }\n}\n\nfunction mapU(r, n) {\n var a = r.length;\n var e = new Array(a);\n for (var t = 0; t < a; ++t) {\n e[t] = n(r[t]);\n }\n return e;\n}\n\nfunction getByU(r, a) {\n var e = r.length;\n var t = 0;\n var v;\n while (void 0 === v && t < e) {\n var f = r[t];\n if (a(f)) {\n v = n(f);\n }\n t = t + 1 | 0;\n }\n return v;\n}\n\nfunction getIndexByU(r, n) {\n var a = r.length;\n var e = 0;\n var t;\n while (void 0 === t && e < a) {\n if (n(r[e])) {\n t = e;\n }\n e = e + 1 | 0;\n }\n return t;\n}\n\nfunction keepMapU(r, n) {\n var e = r.length;\n var t = new Array(e);\n var v = 0;\n for (var f = 0; f < e; ++f) {\n var o = n(r[f]);\n if (void 0 !== o) {\n t[v] = a(o);\n v = v + 1 | 0;\n }\n }\n t.length = v;\n return t;\n}\n\nfunction forEachWithIndexU(r, n) {\n for (var a = 0, e = r.length; a < e; ++a) {\n n(a, r[a]);\n }\n}\n\nfunction mapWithIndexU(r, n) {\n var a = r.length;\n var e = new Array(a);\n for (var t = 0; t < a; ++t) {\n e[t] = n(t, r[t]);\n }\n return e;\n}\n\nfunction reduceU(r, n, a) {\n var e = n;\n for (var t = 0, v = r.length; t < v; ++t) {\n e = a(e, r[t]);\n }\n return e;\n}\n\nfunction reduceReverseU(r, n, a) {\n var e = n;\n for (var t = r.length - 1 | 0; t >= 0; --t) {\n e = a(e, r[t]);\n }\n return e;\n}\n\nfunction reduceWithIndexU(r, n, a) {\n var e = n;\n for (var t = 0, v = r.length; t < v; ++t) {\n e = a(e, r[t], t);\n }\n return e;\n}\n\nfunction everyU(r, n) {\n var a = r.length;\n var e = 0;\n while (1) {\n var t = e;\n if (t === a) {\n return !0;\n }\n if (!n(r[t])) {\n return !1;\n }\n e = t + 1 | 0;\n }\n}\n\nfunction someU(r, n) {\n var a = r.length;\n var e = 0;\n while (1) {\n var t = e;\n if (t === a) {\n return !1;\n }\n if (n(r[t])) {\n return !0;\n }\n e = t + 1 | 0;\n }\n}\n\nfunction eqU(r, n, a) {\n var e = r.length;\n if (e === n.length) {\n return function everyAux2(r, n, a, e, t) {\n while (1) {\n var v = a;\n if (v === t) {\n return !0;\n }\n if (!e(r[v], n[v])) {\n return !1;\n }\n a = v + 1 | 0;\n }\n }(r, n, 0, a, e);\n } else {\n return !1;\n }\n}\n\nfunction partitionU(r, n) {\n var a = r.length;\n var e = 0;\n var t = 0;\n var v = new Array(a);\n var f = new Array(a);\n for (var o = 0; o < a; ++o) {\n var i = r[o];\n if (n(i)) {\n v[e] = i;\n e = e + 1 | 0;\n } else {\n f[t] = i;\n t = t + 1 | 0;\n }\n }\n v.length = e;\n f.length = t;\n return [ v, f ];\n}\n\nfunction unzip(r) {\n var n = r.length;\n var a = new Array(n);\n var e = new Array(n);\n for (var t = 0; t < n; ++t) {\n var v = r[t];\n a[t] = v[0];\n e[t] = v[1];\n }\n return [ a, e ];\n}\n\nexport { zip as A, zipByU as B, forEachWithIndexU as C, getIndexByU as D, keepMapU as E, reduceWithIndexU as a, mapU as b, concat as c, blitUnsafe as d, everyU as e, forEachU as f, reverse as g, get as h, sliceToEnd as i, slice as j, getExn as k, shuffle as l, makeByU as m, concatMany as n, random_int as o, make as p, getByU as q, reduceU as r, someU as s, mapWithIndexU as t, unzip as u, reduceReverseU as v, partitionU as w, eqU as x, range as y, rangeBy as z };\n","import { s as n, v as t } from \"./caml_option-16487d6d.mjs\";\n\nimport { d as r, g as e, h as u, i, j as f, k as a, l as o, n as c, u as s, r as l, a as h, o as p, m as v, p as g, c as _, q as d, b as y, t as m, v as A, w as x, e as B, s as W, x as E, y as k, z as I, A as j, B as w, f as q, C as F, D as T, E as U } from \"./belt_Array-b9ebcaa6.mjs\";\n\nimport { e as b, l as M } from \"./caml_obj-c29533cc.mjs\";\n\nfunction merge(n, t, e, u, i, f, a, o, c) {\n var s = t + e | 0;\n var l = i + f | 0;\n var h = t;\n var p = n[t];\n var v = i;\n var g = u[i];\n var _ = o;\n while (1) {\n var d = _;\n var y = g;\n var m = v;\n var A = p;\n var x = h;\n if (c(A, y) <= 0) {\n a[d] = A;\n var B = x + 1 | 0;\n if (B >= s) {\n return r(u, m, a, d + 1 | 0, l - m | 0);\n }\n _ = d + 1 | 0;\n p = n[B];\n h = B;\n continue;\n }\n a[d] = y;\n var W = m + 1 | 0;\n if (W >= l) {\n return r(n, x, a, d + 1 | 0, s - x | 0);\n }\n _ = d + 1 | 0;\n g = u[W];\n v = W;\n }\n}\n\nfunction insertionSort(n, t, r, e, u, i) {\n for (var f = 0; f < u; ++f) {\n var a = n[t + f | 0];\n var o = (e + f | 0) - 1 | 0;\n while (o >= e && i(r[o], a) > 0) {\n r[o + 1 | 0] = r[o];\n o = o - 1 | 0;\n }\n r[o + 1 | 0] = a;\n }\n}\n\nfunction sortTo(n, t, r, e, u, i) {\n if (u <= 5) {\n return insertionSort(n, t, r, e, u, i);\n }\n var f = u / 2 | 0;\n var a = u - f | 0;\n sortTo(n, t + f | 0, r, e + f | 0, a, i);\n sortTo(n, t, n, t + a | 0, f, i);\n merge(n, t + a | 0, f, r, e + f | 0, a, r, e, i);\n}\n\nfunction stableSortByU(n, t) {\n var r = n.slice(0);\n !function stableSortInPlaceByU(n, t) {\n var r = n.length;\n if (r <= 5) {\n return insertionSort(n, 0, n, 0, r, t);\n }\n var e = r / 2 | 0;\n var u = r - e | 0;\n var i = new Array(u);\n sortTo(n, e, i, 0, u, t);\n sortTo(n, 0, n, u, e, t);\n merge(n, u, e, i, 0, u, n, 0, t);\n }(r, t);\n return r;\n}\n\nfunction get$1(t, r) {\n if (r in t) {\n return n(t[r]);\n }\n}\n\nvar unsafeDeleteKey = function(n, t) {\n delete n[t];\n};\n\nfunction values(n) {\n var t = Object.keys(n);\n var r = t.length;\n var e = new Array(r);\n for (var u = 0; u < r; ++u) {\n e[u] = n[t[u]];\n }\n return e;\n}\n\nfunction fromArray(n) {\n var t = {};\n var r = n.length;\n for (var e = 0; e < r; ++e) {\n var u = n[e];\n t[u[0]] = u[1];\n }\n return t;\n}\n\nfunction placeholder(n) {}\n\nfunction makeEmpty(n) {\n return [];\n}\n\nvar z = v;\n\nfunction makeWithIndex() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return z(t, n[0]);\n };\n }\n return z(arguments[0], arguments[1]);\n}\n\nvar S = g;\n\nfunction make() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return S(t, n[0]);\n };\n }\n return S(arguments[0], arguments[1]);\n}\n\nvar O = g;\n\nfunction repeat() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return O(t, n[0]);\n };\n }\n return O(arguments[0], arguments[1]);\n}\n\nfunction length(n) {\n return n.length;\n}\n\nfunction isEmpty(n) {\n return 0 === n.length;\n}\n\nfunction isNotEmpty(n) {\n return 0 !== n.length;\n}\n\nvar $ = e;\n\nfunction _append(n, t) {\n return _(n, [ t ]);\n}\n\nfunction append() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _append(t, n[0]);\n };\n }\n return _append(arguments[0], arguments[1]);\n}\n\nfunction _prepend(n, t) {\n return _([ t ], n);\n}\n\nfunction prepend() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _prepend(t, n[0]);\n };\n }\n return _prepend(arguments[0], arguments[1]);\n}\n\nfunction _prependToAll(n, t) {\n return l(n, [], (function(n, r) {\n return _(n, [ t, r ]);\n }));\n}\n\nfunction prependToAll() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _prependToAll(t, n[0]);\n };\n }\n return _prependToAll(arguments[0], arguments[1]);\n}\n\nfunction _intersperse(n, t) {\n return h(n, [], (function(r, e, u) {\n if ((n.length - 1 | 0) === u) {\n r.push(e);\n } else {\n r.push(e, t);\n }\n return r;\n }));\n}\n\nfunction intersperse() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _intersperse(t, n[0]);\n };\n }\n return _intersperse(arguments[0], arguments[1]);\n}\n\nvar C = u;\n\nfunction get() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return C(t, n[0]);\n };\n }\n return C(arguments[0], arguments[1]);\n}\n\nvar D = u;\n\nfunction at() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return D(t, n[0]);\n };\n }\n return D(arguments[0], arguments[1]);\n}\n\nfunction _getUnsafe(n, t) {\n return n[t];\n}\n\nfunction getUnsafe() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _getUnsafe(t, n[0]);\n };\n }\n return _getUnsafe(arguments[0], arguments[1]);\n}\n\nfunction _getUndefined(n, t) {\n return n[t];\n}\n\nfunction getUndefined() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _getUndefined(t, n[0]);\n };\n }\n return _getUndefined(arguments[0], arguments[1]);\n}\n\nvar N = d;\n\nfunction getBy() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return N(t, n[0]);\n };\n }\n return N(arguments[0], arguments[1]);\n}\n\nvar R = d;\n\nfunction find() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return R(t, n[0]);\n };\n }\n return R(arguments[0], arguments[1]);\n}\n\nfunction head(n) {\n return u(n, 0);\n}\n\nfunction last(n) {\n var t = n.length;\n if (0 === t) {\n return;\n } else {\n return u(n, t - 1 | 0);\n }\n}\n\nfunction tail(n) {\n var t = n.length;\n if (1 === t) {\n return [];\n }\n if (0 === t) {\n return;\n }\n var r = i(n, 1);\n if (0 !== r.length) {\n return r;\n }\n}\n\nfunction tailOrEmpty(n) {\n var t = tail(n);\n if (void 0 !== t) {\n return t;\n } else {\n return [];\n }\n}\n\nfunction init(n) {\n var t = n.length;\n if (0 === t) {\n return;\n } else {\n return f(n, 0, t - 1 | 0);\n }\n}\n\nfunction initOrEmpty(n) {\n var t = init(n);\n if (void 0 !== t) {\n return t;\n } else {\n return [];\n }\n}\n\nfunction _take(n, t) {\n var r = n.length;\n return f(n, 0, t < 0 ? 0 : r < t ? r : t);\n}\n\nfunction take() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _take(t, n[0]);\n };\n }\n return _take(arguments[0], arguments[1]);\n}\n\nfunction _takeExactly(n, t) {\n if (t < 0 || t > n.length) {\n return;\n } else {\n return f(n, 0, t);\n }\n}\n\nfunction takeExactly() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _takeExactly(t, n[0]);\n };\n }\n return _takeExactly(arguments[0], arguments[1]);\n}\n\nfunction _takeWhile(n, t) {\n var r = 0;\n var e = !1;\n var u = [];\n while (r < n.length && !e) {\n var i = n[r];\n if (t(i)) {\n u.push(i);\n r = r + 1 | 0;\n } else {\n e = !0;\n }\n }\n return u;\n}\n\nfunction takeWhile() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _takeWhile(t, n[0]);\n };\n }\n return _takeWhile(arguments[0], arguments[1]);\n}\n\nfunction _drop(n, t) {\n var r = n.length;\n return i(n, t < 0 ? 0 : r < t ? r : t);\n}\n\nfunction drop() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _drop(t, n[0]);\n };\n }\n return _drop(arguments[0], arguments[1]);\n}\n\nfunction _dropExactly(n, t) {\n if (t < 0 || t > n.length) {\n return;\n } else {\n return i(n, t);\n }\n}\n\nfunction dropExactly() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _dropExactly(t, n[0]);\n };\n }\n return _dropExactly(arguments[0], arguments[1]);\n}\n\nfunction _dropWhile(n, t) {\n return l(n, [], (function(n, r) {\n if (!t(r)) {\n n.push(r);\n }\n return n;\n }));\n}\n\nfunction dropWhile() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _dropWhile(t, n[0]);\n };\n }\n return _dropWhile(arguments[0], arguments[1]);\n}\n\nfunction uncons(n) {\n if (0 !== n.length) {\n return [ a(n, 0), i(n, 1) ];\n }\n}\n\nfunction _map(n, t) {\n return y(n, t);\n}\n\nfunction map() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _map(t, n[0]);\n };\n }\n return _map(arguments[0], arguments[1]);\n}\n\nvar G = m;\n\nfunction mapWithIndex() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return G(t, n[0]);\n };\n }\n return G(arguments[0], arguments[1]);\n}\n\nfunction _filter(n, t) {\n var r = 0;\n var e = [];\n while (r < n.length) {\n var u = n[r];\n if (t(u)) {\n e.push(u);\n }\n r = r + 1 | 0;\n }\n return e;\n}\n\nfunction filter() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _filter(t, n[0]);\n };\n }\n return _filter(arguments[0], arguments[1]);\n}\n\nvar P = filter;\n\nfunction _filterWithIndex(n, t) {\n var r = 0;\n var e = [];\n while (r < n.length) {\n var u = n[r];\n if (t(r, u)) {\n e.push(u);\n }\n r = r + 1 | 0;\n }\n return e;\n}\n\nfunction filterWithIndex() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _filterWithIndex(t, n[0]);\n };\n }\n return _filterWithIndex(arguments[0], arguments[1]);\n}\n\nvar H = filterWithIndex;\n\nfunction _reject(n, t) {\n return filter(n, (function(n) {\n return !t(n);\n }));\n}\n\nfunction reject() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _reject(t, n[0]);\n };\n }\n return _reject(arguments[0], arguments[1]);\n}\n\nfunction _rejectWithIndex(n, t) {\n return filterWithIndex(n, (function(n, r) {\n return !t(n, r);\n }));\n}\n\nfunction rejectWithIndex() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _rejectWithIndex(t, n[0]);\n };\n }\n return _rejectWithIndex(arguments[0], arguments[1]);\n}\n\nvar J = l;\n\nfunction reduce() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return J(t, n[0], n[1]);\n };\n }\n return J(arguments[0], arguments[1], arguments[2]);\n}\n\nvar K = A;\n\nfunction reduceReverse() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return K(t, n[0], n[1]);\n };\n }\n return K(arguments[0], arguments[1], arguments[2]);\n}\n\nvar L = h;\n\nfunction reduceWithIndex() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return L(t, n[0], n[1]);\n };\n }\n return L(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _splitAt(n, t) {\n if (t < 0 || t > n.length) {\n return;\n } else {\n return [ f(n, 0, t), i(n, t) ];\n }\n}\n\nfunction splitAt() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _splitAt(t, n[0]);\n };\n }\n return _splitAt(arguments[0], arguments[1]);\n}\n\nfunction _splitEvery(n, t) {\n if (t < 1 || n.length <= t) {\n return [ n ];\n }\n var r = 0;\n var e = [];\n while (r < n.length) {\n var u = r + t | 0;\n e.push(f(n, r, t));\n r = u;\n }\n return e;\n}\n\nfunction splitEvery() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _splitEvery(t, n[0]);\n };\n }\n return _splitEvery(arguments[0], arguments[1]);\n}\n\nvar Q = o;\n\nvar V = x;\n\nfunction partition() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return V(t, n[0]);\n };\n }\n return V(arguments[0], arguments[1]);\n}\n\nvar X = _;\n\nfunction concat() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return X(t, n[0]);\n };\n }\n return X(arguments[0], arguments[1]);\n}\n\nvar Y = c;\n\nvar Z = B;\n\nfunction every() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return Z(t, n[0]);\n };\n }\n return Z(arguments[0], arguments[1]);\n}\n\nvar nn = W;\n\nfunction some() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return nn(t, n[0]);\n };\n }\n return nn(arguments[0], arguments[1]);\n}\n\nvar tn = f;\n\nfunction slice() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return tn(t, n[0], n[1]);\n };\n }\n return tn(arguments[0], arguments[1], arguments[2]);\n}\n\nvar rn = i;\n\nfunction sliceToEnd() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return rn(t, n[0]);\n };\n }\n return rn(arguments[0], arguments[1]);\n}\n\nvar en = E;\n\nfunction eq() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return en(t, n[0], n[1]);\n };\n }\n return en(arguments[0], arguments[1], arguments[2]);\n}\n\nvar un = k;\n\nfunction range() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return un(t, n[0]);\n };\n }\n return un(arguments[0], arguments[1]);\n}\n\nvar an = I;\n\nfunction rangeBy() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return an(t, n[0], n[1]);\n };\n }\n return an(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction copy(n) {\n return n.slice(0);\n}\n\nvar on = j;\n\nfunction zip() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return on(t, n[0]);\n };\n }\n return on(arguments[0], arguments[1]);\n}\n\nvar cn = w;\n\nfunction zipWith() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return cn(t, n[0], n[1]);\n };\n }\n return cn(arguments[0], arguments[1], arguments[2]);\n}\n\nvar sn = s;\n\nfunction _replaceAt(n, t, r) {\n return m(n, (function(n, e) {\n if (n === t) {\n return r;\n } else {\n return e;\n }\n }));\n}\n\nfunction replaceAt() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _replaceAt(t, n[0], n[1]);\n };\n }\n return _replaceAt(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _insertAt(n, t, r) {\n var e = splitAt(n, t);\n if (void 0 !== e) {\n return _(e[0], _([ r ], e[1]));\n } else {\n return n;\n }\n}\n\nfunction insertAt() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _insertAt(t, n[0], n[1]);\n };\n }\n return _insertAt(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _updateAt(n, t, r) {\n return m(n, (function(n, e) {\n if (n === t) {\n return r(e);\n } else {\n return e;\n }\n }));\n}\n\nfunction updateAt() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _updateAt(t, n[0], n[1]);\n };\n }\n return _updateAt(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _swapAt(n, r, e) {\n var i = u(n, r);\n var f = u(n, e);\n if (void 0 === i) {\n return n;\n }\n if (void 0 === f) {\n return n;\n }\n var a = t(f);\n var o = t(i);\n return m(n, (function(n, t) {\n if (r === n) {\n return a;\n } else if (e === n) {\n return o;\n } else {\n return t;\n }\n }));\n}\n\nfunction swapAt() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _swapAt(t, n[0], n[1]);\n };\n }\n return _swapAt(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _removeAt(n, t) {\n return filterWithIndex(n, (function(n, r) {\n return n !== t;\n }));\n}\n\nfunction removeAt() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _removeAt(t, n[0]);\n };\n }\n return _removeAt(arguments[0], arguments[1]);\n}\n\nfunction _uniqBy(n, t) {\n var r = 0;\n var e = [];\n while (r < n.length) {\n var u = n[r];\n var i = W(e, function(n) {\n return function(r) {\n return b(t(r), t(n));\n };\n }(u));\n if (!i) {\n e.push(u);\n }\n r = r + 1 | 0;\n }\n return e;\n}\n\nfunction uniqBy() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _uniqBy(t, n[0]);\n };\n }\n return _uniqBy(arguments[0], arguments[1]);\n}\n\nfunction uniq(n) {\n return uniqBy(n, (function(n) {\n return n;\n }));\n}\n\nvar ln = q;\n\nfunction forEach() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return ln(t, n[0]);\n };\n }\n return ln(arguments[0], arguments[1]);\n}\n\nvar hn = F;\n\nfunction forEachWithIndex() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return hn(t, n[0]);\n };\n }\n return hn(arguments[0], arguments[1]);\n}\n\nvar pn = T;\n\nfunction getIndexBy() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return pn(t, n[0]);\n };\n }\n return pn(arguments[0], arguments[1]);\n}\n\nfunction _includes(n, t) {\n return W(n, (function(n) {\n return b(n, t);\n }));\n}\n\nfunction includes() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _includes(t, n[0]);\n };\n }\n return _includes(arguments[0], arguments[1]);\n}\n\nfunction _join(n, t) {\n return n.join(t);\n}\n\nfunction join() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _join(t, n[0]);\n };\n }\n return _join(arguments[0], arguments[1]);\n}\n\nvar vn = stableSortByU;\n\nfunction sort() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return vn(t, n[0]);\n };\n }\n return vn(arguments[0], arguments[1]);\n}\n\nfunction _sortBy(n, t) {\n return stableSortByU(n, (function(n, r) {\n var e = t(n);\n var u = t(r);\n if (e === u) {\n return 0;\n } else if (M(e, u)) {\n return -1;\n } else {\n return 1;\n }\n }));\n}\n\nfunction sortBy() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _sortBy(t, n[0]);\n };\n }\n return _sortBy(arguments[0], arguments[1]);\n}\n\nfunction _groupBy(n, t) {\n return l(n, {}, (function(n, r) {\n var e = t(r);\n var u = get$1(n, e);\n if (void 0 !== u) {\n u.push(r);\n } else {\n n[e] = [ r ];\n }\n return n;\n }));\n}\n\nfunction groupBy() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _groupBy(t, n[0]);\n };\n }\n return _groupBy(arguments[0], arguments[1]);\n}\n\nfunction flat(n) {\n return l(n, [], (function(n, t) {\n if (Array.isArray(t)) {\n q(t, (function(t) {\n n.push(t);\n }));\n } else {\n n.push(t);\n }\n return n;\n }));\n}\n\nfunction _flatten(n, t) {\n var r = 0;\n while (r < n.length) {\n var e = n[r];\n if (Array.isArray(e)) {\n flatten(e, t);\n } else {\n t.push(e);\n }\n r = r + 1 | 0;\n }\n return t;\n}\n\nfunction flatten() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _flatten(t, n[0]);\n };\n }\n return _flatten(arguments[0], arguments[1]);\n}\n\nfunction deepFlat(n) {\n return flatten(n, []);\n}\n\nfunction toTuple(n) {\n return n;\n}\n\nfunction _tap(n, t) {\n q(n, t);\n return n;\n}\n\nfunction tap() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _tap(t, n[0]);\n };\n }\n return _tap(arguments[0], arguments[1]);\n}\n\nfunction flip(n) {\n return [ n[1], n[0] ];\n}\n\nvar gn = U;\n\nfunction filterMap() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return gn(t, n[0]);\n };\n }\n return gn(arguments[0], arguments[1]);\n}\n\nvar _n = U;\n\nfunction keepMap() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _n(t, n[0]);\n };\n }\n return _n(arguments[0], arguments[1]);\n}\n\nfunction _removeFirstBy(n, t, r) {\n return l(n, [ !1, [] ], (function(n, e) {\n var u = n[1];\n if (n[0]) {\n u.push(e);\n return [ !0, u ];\n } else if (r(e, t)) {\n return [ !0, u ];\n } else {\n u.push(e);\n return [ !1, u ];\n }\n }))[1];\n}\n\nfunction removeFirstBy() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _removeFirstBy(t, n[0], n[1]);\n };\n }\n return _removeFirstBy(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _removeFirst(n, t) {\n return removeFirstBy(n, t, b);\n}\n\nfunction removeFirst() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _removeFirst(t, n[0]);\n };\n }\n return _removeFirst(arguments[0], arguments[1]);\n}\n\nfunction zipWithIndex(n) {\n return h(n, [], (function(n, t, r) {\n n.push([ t, r ]);\n return n;\n }));\n}\n\nfunction _all(n, t) {\n return B(n, t);\n}\n\nfunction all() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _all(t, n[0]);\n };\n }\n return _all(arguments[0], arguments[1]);\n}\n\nfunction _any(n, t) {\n return W(n, t);\n}\n\nfunction any() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _any(t, n[0]);\n };\n }\n return _any(arguments[0], arguments[1]);\n}\n\nfunction _difference(n, t) {\n return reject(uniqBy(n, (function(n) {\n return n;\n })), (function(n) {\n return includes(t, n);\n }));\n}\n\nfunction difference() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _difference(t, n[0]);\n };\n }\n return _difference(arguments[0], arguments[1]);\n}\n\nfunction _union(n, t) {\n return uniqBy(_(n, t), (function(n) {\n return n;\n }));\n}\n\nfunction union() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _union(t, n[0]);\n };\n }\n return _union(arguments[0], arguments[1]);\n}\n\nfunction _intersection(n, t) {\n var r = n.length > t.length ? [ n, t ] : [ t, n ];\n var e = r[1];\n return uniqBy(filter(r[0], (function(n) {\n return includes(e, n);\n })), (function(n) {\n return n;\n }));\n}\n\nfunction intersection() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _intersection(t, n[0]);\n };\n }\n return _intersection(arguments[0], arguments[1]);\n}\n\nfunction sample(n) {\n return n[p(0, n.length - 1 | 0)];\n}\n\nfunction _flatMap(n, t) {\n return flat(y(n, t));\n}\n\nfunction flatMap() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _flatMap(t, n[0]);\n };\n }\n return _flatMap(arguments[0], arguments[1]);\n}\n\nexport { eq as $, takeExactly as A, takeWhile as B, drop as C, dropExactly as D, dropWhile as E, uncons as F, map as G, mapWithIndex as H, filter as I, P as J, filterWithIndex as K, H as L, reject as M, rejectWithIndex as N, reduce as O, reduceReverse as P, reduceWithIndex as Q, splitAt as R, splitEvery as S, Q as T, partition as U, concat as V, Y as W, every as X, some as Y, slice as Z, sliceToEnd as _, makeWithIndex as a, range as a0, rangeBy as a1, copy as a2, zip as a3, zipWith as a4, sn as a5, replaceAt as a6, insertAt as a7, updateAt as a8, swapAt as a9, intersection as aA, sample as aB, flatMap as aC, values as aD, fromArray as aE, get$1 as aF, unsafeDeleteKey as aG, removeAt as aa, uniqBy as ab, uniq as ac, forEach as ad, forEachWithIndex as ae, getIndexBy as af, includes as ag, join as ah, sort as ai, sortBy as aj, groupBy as ak, flat as al, flatten as am, deepFlat as an, toTuple as ao, tap as ap, flip as aq, filterMap as ar, keepMap as as, removeFirstBy as at, removeFirst as au, zipWithIndex as av, all as aw, any as ax, difference as ay, union as az, make as b, isNotEmpty as c, $ as d, append as e, prepend as f, prependToAll as g, intersperse as h, isEmpty as i, get as j, at as k, length as l, makeEmpty as m, getUnsafe as n, getUndefined as o, placeholder as p, getBy as q, repeat as r, find as s, head as t, last as u, tail as v, tailOrEmpty as w, init as x, initOrEmpty as y, take as z };\n","import { p as a, m as s, a as e, b as t, r as i, l as r, i as p, c as n, d as l, e as o, f as d, g as c, h as y, j as m, k as f, n as h, o as u, q as x, s as E, t as W, u as g, v as k, w as v, x as A, y as I, z as B, A as j, B as z, C as q, D as M, E as _, F, G as T, H as b, I as w, J as O, K as U, L as C, M as N, N as R, O as D, P as G, Q as H, R as J, S as K, T as L, U as P, V as Q, W as S, X as V, Y as X, Z as Y, _ as Z, $, a0 as aa, a1 as sa, a2 as ea, a3 as ta, a4 as ia, a5 as ra, a6 as pa, a7 as na, a8 as la, a9 as oa, aa as da, ab as ca, ac as ya, ad as ma, ae as fa, af as ha, ag as ua, ah as xa, ai as Ea, aj as Wa, ak as ga, al as ka, am as va, an as Aa, ao as Ia, ap as Ba, aq as ja, ar as za, as as qa, at as Ma, au as _a, av as Fa, aw as Ta, ax as ba, ay as wa, az as Oa, aA as Ua, aB as Ca, aC as Na } from \"./Array.bs-4b4ec77c.mjs\";\n\nvar Ra = {\n __proto__: null,\n placeholder: a,\n makeEmpty: s,\n makeWithIndex: e,\n make: t,\n repeat: i,\n length: r,\n isEmpty: p,\n isNotEmpty: n,\n reverse: l,\n append: o,\n prepend: d,\n prependToAll: c,\n intersperse: y,\n get: m,\n at: f,\n getUnsafe: h,\n getUndefined: u,\n getBy: x,\n find: E,\n head: W,\n last: g,\n tail: k,\n tailOrEmpty: v,\n init: A,\n initOrEmpty: I,\n take: B,\n takeExactly: j,\n takeWhile: z,\n drop: q,\n dropExactly: M,\n dropWhile: _,\n uncons: F,\n map: T,\n mapWithIndex: b,\n filter: w,\n keep: O,\n filterWithIndex: U,\n keepWithIndex: C,\n reject: N,\n rejectWithIndex: R,\n reduce: D,\n reduceReverse: G,\n reduceWithIndex: H,\n splitAt: J,\n splitEvery: K,\n shuffle: L,\n partition: P,\n concat: Q,\n concatMany: S,\n every: V,\n some: X,\n slice: Y,\n sliceToEnd: Z,\n eq: $,\n range: aa,\n rangeBy: sa,\n copy: ea,\n zip: ta,\n zipWith: ia,\n unzip: ra,\n replaceAt: pa,\n insertAt: na,\n updateAt: la,\n swapAt: oa,\n removeAt: da,\n uniqBy: ca,\n uniq: ya,\n forEach: ma,\n forEachWithIndex: fa,\n getIndexBy: ha,\n includes: ua,\n join: xa,\n sort: Ea,\n sortBy: Wa,\n groupBy: ga,\n flat: ka,\n flatten: va,\n deepFlat: Aa,\n toTuple: Ia,\n tap: Ba,\n flip: ja,\n filterMap: za,\n keepMap: qa,\n removeFirstBy: Ma,\n removeFirst: _a,\n zipWithIndex: Fa,\n all: Ta,\n any: ba,\n difference: wa,\n union: Oa,\n intersection: Ua,\n sample: Ca,\n flatMap: Na\n};\n\nexport { Ra as i };\n","function _is(i, n) {\n return typeof i === n;\n}\n\nfunction is() {\n if (1 === arguments.length) {\n const i = arguments;\n return function fn(n) {\n return _is(n, i[0]);\n };\n }\n return _is(arguments[0], arguments[1]);\n}\n\nfunction isString(i) {\n return \"string\" == typeof i;\n}\n\nfunction isNumber(i) {\n if (\"number\" == typeof i) {\n return !Number.isNaN(i);\n } else {\n return !1;\n }\n}\n\nfunction isBoolean(i) {\n return \"boolean\" == typeof i;\n}\n\nvar isPromise = i => i instanceof Promise;\n\nfunction isArray(i) {\n return Array.isArray(i);\n}\n\nfunction isObject(i) {\n if (i && !Array.isArray(i)) {\n return \"object\" == typeof i;\n } else {\n return !1;\n }\n}\n\nfunction isFunction(i) {\n return \"function\" == typeof i;\n}\n\nvar isError = i => i instanceof Error;\n\nvar isDate = i => i instanceof Date;\n\nfunction isNullable(i) {\n return null == i;\n}\n\nfunction isNotNullable(i) {\n return !(null == i);\n}\n\nvar isNull = i => null === i;\n\nvar isUndefined = i => void 0 === i;\n\nfunction _isNot(i, n) {\n return !n(i);\n}\n\nfunction isNot() {\n if (1 === arguments.length) {\n const i = arguments;\n return function fn(n) {\n return _isNot(n, i[0]);\n };\n }\n return _isNot(arguments[0], arguments[1]);\n}\n\nvar i = {\n __proto__: null,\n is,\n isString,\n isNumber,\n isBoolean,\n isPromise,\n isArray,\n isObject,\n isFunction,\n isError,\n isDate,\n isNullable,\n isNotNullable,\n isNull,\n isUndefined,\n isNot\n};\n\nexport { is as a, isString as b, isNumber as c, isBoolean as d, isPromise as e, isArray as f, isObject as g, isFunction as h, i, isError as j, isDate as k, isNullable as l, isNotNullable as m, isNull as n, isUndefined as o, isNot as p };\n","/** Constantes de valeurs pour la manipulation du DOM : sélecteurs et attributs. */\n\nexport const ATTRIBUT_ACTIF = \"data-actif\";\nexport const ATTRIBUT_ARIA_CONTROLS = \"aria-controls\";\nexport const ATTRIBUT_ARIA_EXPANDED = \"aria-expanded\";\nexport const ATTRIBUT_ARIA_HIDDEN = \"aria-hidden\";\nexport const ATTRIBUT_ARIA_SELECTED = \"aria-selected\";\nexport const ATTRIBUT_CACHÉ = \"data-caché\";\nexport const ATTRIBUT_CHARGEMENT = \"data-chargement\";\nexport const ATTRIBUT_CLE_PANIER = \"data-cle-panier\";\nexport const ATTRIBUT_CODE_PROMO_PRESENT = \"data-code-promo-present\";\nexport const ATTRIBUT_CONTIENT_ARTICLES = \"data-contient-articles\";\nexport const ATTRIBUT_DESACTIVE = \"disabled\";\nexport const ATTRIBUT_ENSEMBLE_EPINGLE_BOITE_ACTIF = \"data-ensemble-epingle-boite-actif\";\nexport const ATTRIBUT_HIDDEN = \"hidden\";\nexport const ATTRIBUT_ID_CATEGORIE_PRODUITS = \"data-id-categorie-produits\";\nexport const ATTRIBUT_ID_ENSEMBLE_EPINGLE_BOITE = \"data-id-ensemble-epingle-boite\";\nexport const ATTRIBUT_INDEX = \"data-index\";\nexport const ATTRIBUT_INDEX_IMAGE_ACTIVE = \"data-index-image-active\";\nexport const ATTRIBUT_LIVRAISON_VALIDEE = \"data-livraison-validee\";\nexport const ATTRIBUT_MENU_MOBILE_ACTIVE = \"data-menu-mobile-active\";\nexport const ATTRIBUT_PAGE = \"data-page\";\nexport const ATTRIBUT_PRIX = \"data-prix\";\nexport const ATTRIBUT_TABINDEX = \"tabindex\";\n\n// En-tête\nexport const DOM_BOUTON_MENU_MOBILE = \"#bouton-menu-mobile\";\nexport const DOM_BOUTON_PANIER = \".compte-panier a[rel='cart']\";\nexport const DOM_ENTREE_MENU_CATEGORIES_PRODUITS = \"#menu-categories-produits ul li a\";\nexport const DOM_MENU_CATEGORIES_PRODUITS = \"#menu-categories-produits\";\nexport const DOM_MENU_MOBILE = \"#menu-mobile\";\n\n// Panier\nexport const DOM_BOUTON_ACTIONS_FORMULAIRE = \"#panneau-informations-client .panneau__pied-de-page button\";\nexport const DOM_BOUTON_ADDITION_QUANTITE = \"button.detail-produit__actions__addition\";\nexport const DOM_BOUTON_CODE_PROMO = \"#panneau-panier #bouton-code-promo\";\nexport const DOM_BOUTON_SEPARATION_ADRESSES = \"#separation-adresses\";\nexport const DOM_BOUTON_SOUSTRACTION_QUANTITE = \"button.detail-produit__actions__soustraction\";\nexport const DOM_BOUTON_SUPPRESSION_PANIER = \"button.detail-produit__actions__suppression\";\nexport const DOM_CHAMP_CODE_PROMO = \"#panneau-panier #champ-code-promo\";\nexport const DOM_CHAMP_QUANTITE_LIGNE_PANIER = \"input\";\nexport const DOM_CONTENEUR_METHODES_LIVRAISON = \"#panneau-panier #choix-methode-livraison\";\nexport const DOM_ENSEMBLE_CODE_PROMO = \"#panneau-panier #ensemble-code-promo\";\nexport const DOM_ENTREES_PANIER = \"article\";\nexport const DOM_FORMULAIRE_FACTURATION = \"#panneau-informations-client .panneau__formulaires__facturation\";\nexport const DOM_FORMULAIRE_LIVRAISON = \"#panneau-informations-client .panneau__formulaires__livraison\";\nexport const DOM_FORMULAIRE_PANIER = \"#panneau-informations-client form\";\nexport const DOM_INSTRUCTIONS_CLIENT = \"#panneau-panier #instructions-client\";\nexport const DOM_MESSAGE_CODE_PROMO = \"#panneau-panier .panneau__instructions-code-promo__code-promo__message\";\nexport const DOM_MESSAGE_FORMULAIRE_ADRESSES = \"#panneau-informations-client #message-formulaire-adresses\";\nexport const DOM_PRIX_LIGNE_PANIER = \".detail-produit__nom-prix span\";\nexport const DOM_SOUS_TOTAL_LIVRAISON_COUT = \"#panneau-panier #sous-total-livraison strong\";\nexport const DOM_SOUS_TOTAL_LIVRAISON_PRESTATAIRE = \"#panneau-panier #sous-total-livraison span\";\nexport const DOM_SOUS_TOTAL_PRODUITS = \"#panneau-panier #sous-total-produits strong\";\nexport const DOM_TOTAL_PANIER = \"#panneau-panier .panneau__pied-de-page p span\";\nexport const DOM_TOTAL_REDUCTION = \"#panneau-panier #sous-total-reduction\";\nexport const DOM_TOTAL_REDUCTION_VALEUR = \"#panneau-panier #sous-total-reduction strong\";\n\n// Accueil\nexport const DOM_CONTENEUR_ANIMATION = \".storytelling__animation\";\nexport const DOM_CONTENEUR_STORYTELLING = \".storytelling\";\nexport const DOM_GARDE_FOU_JS = \"no-js\";\nexport const DOM_IMAGES_STORYTELLING = \".storytelling__image\";\n\n// Boutique\nexport const DOM_BOUTON_PLUS_PRODUITS = \"#page-boutique #bouton-plus-de-produits\";\nexport const DOM_GRILLE_PRODUITS = \"#page-boutique .grille-produits\";\n\n// À propos\nexport const CLASS_BOITE_TEXTE = \"boite-texte\";\nexport const CLASS_BOUTON_FERMETURE_BOITE_TEXTE = \"boite-texte__bouton-fermeture\";\nexport const CLASS_EPINGLE = \"epingle\";\nexport const DOM_BOITE_TEXTE = `.${CLASS_BOITE_TEXTE}`;\nexport const DOM_BOUTON_FERMETURE_BOITE_TEXTE = `.${CLASS_BOUTON_FERMETURE_BOITE_TEXTE}`;\nexport const DOM_CONTENEUR_STORYTELLING_A_PROPOS = \".storytelling__conteneur\";\nexport const DOM_EPINGLE = `.${CLASS_EPINGLE}`;\n\n// Produit\nexport const DOM_BOUTON_AJOUT_PANIER = \"#bouton-ajout-panier\";\nexport const DOM_CONTENEUR_PANIER = \"#page-panier\";\nexport const DOM_PRIX_PRODUIT = \".selecteur-produit__prix\";\nexport const DOM_DOM_QUANTITE = \"#selecteur-variation\";\nexport const DOM_BOUTONS_ACCORDEON = \".section-textuelle button\";\nexport const DOM_CONTENUS_ACCORDEON = \".section-textuelle__contenu\";\n","import { Left, Right } from './Either.js';\nexport const Maybe = {\n of(value) {\n return just(value);\n },\n empty() {\n return nothing;\n },\n zero() {\n return nothing;\n },\n fromNullable(value) {\n return value == null ? nothing : just(value);\n },\n fromFalsy(value) {\n return value ? just(value) : nothing;\n },\n fromPredicate(pred, value) {\n switch (arguments.length) {\n case 1:\n return (value) => Maybe.fromPredicate(pred, value);\n default:\n return pred(value) ? just(value) : nothing;\n }\n },\n mapMaybe(f, list) {\n switch (arguments.length) {\n case 1:\n return (list) => Maybe.mapMaybe(f, list);\n default:\n return Maybe.catMaybes(list.map(f));\n }\n },\n catMaybes(list) {\n let res = [];\n for (const e of list) {\n if (e.isJust()) {\n res.push(e.extract());\n }\n }\n return res;\n },\n encase(thunk) {\n try {\n return just(thunk());\n }\n catch {\n return nothing;\n }\n },\n isMaybe(x) {\n return x instanceof Just || x instanceof Nothing;\n },\n sequence(maybes) {\n let res = [];\n for (const m of maybes) {\n if (m.isJust()) {\n res.push(m.extract());\n }\n else {\n return nothing;\n }\n }\n return just(res);\n },\n 'fantasy-land/of'(value) {\n return this.of(value);\n },\n 'fantasy-land/empty'() {\n return this.empty();\n },\n 'fantasy-land/zero'() {\n return this.zero();\n }\n};\nclass Just {\n constructor(__value) {\n this.__value = __value;\n }\n isJust() {\n return true;\n }\n isNothing() {\n return false;\n }\n inspect() {\n return `Just(${this.__value})`;\n }\n [Symbol.for('nodejs.util.inspect.custom')](_depth, opts, inspect) {\n return `Just(${inspect(this.__value, opts)})`;\n }\n toString() {\n return this.inspect();\n }\n toJSON() {\n const value = this.__value;\n return value instanceof Date ? value.toJSON() : value;\n }\n equals(other) {\n return this.extract() === other.extract();\n }\n map(f) {\n return just(f(this.__value));\n }\n ap(maybeF) {\n return maybeF.isJust() ? this.map(maybeF.extract()) : nothing;\n }\n alt(_) {\n return this;\n }\n altLazy(_) {\n return this;\n }\n chain(f) {\n return f(this.__value);\n }\n chainNullable(f) {\n return Maybe.fromNullable(f(this.__value));\n }\n join() {\n return this.__value;\n }\n reduce(reducer, initialValue) {\n return reducer(initialValue, this.__value);\n }\n extend(f) {\n return just(f(this));\n }\n unsafeCoerce() {\n return this.__value;\n }\n caseOf(patterns) {\n return '_' in patterns ? patterns._() : patterns.Just(this.__value);\n }\n orDefault(_) {\n return this.__value;\n }\n orDefaultLazy(_) {\n return this.__value;\n }\n toList() {\n return [this.__value];\n }\n mapOrDefault(f, _) {\n return f(this.__value);\n }\n extract() {\n return this.__value;\n }\n extractNullable() {\n return this.__value;\n }\n toEither(_) {\n return Right(this.__value);\n }\n ifJust(effect) {\n return effect(this.__value), this;\n }\n ifNothing(_) {\n return this;\n }\n filter(pred) {\n return pred(this.__value) ? just(this.__value) : nothing;\n }\n}\nJust.prototype['fantasy-land/equals'] = Just.prototype.equals;\nJust.prototype['fantasy-land/map'] = Just.prototype.map;\nJust.prototype['fantasy-land/ap'] = Just.prototype.ap;\nJust.prototype['fantasy-land/alt'] = Just.prototype.alt;\nJust.prototype['fantasy-land/chain'] = Just.prototype.chain;\nJust.prototype['fantasy-land/reduce'] = Just.prototype.reduce;\nJust.prototype['fantasy-land/extend'] = Just.prototype.extend;\nJust.prototype['fantasy-land/filter'] = Just.prototype.filter;\nJust.prototype.constructor = Maybe;\nclass Nothing {\n isJust() {\n return false;\n }\n isNothing() {\n return true;\n }\n inspect() {\n return 'Nothing';\n }\n [Symbol.for('nodejs.util.inspect.custom')]() {\n return 'Nothing';\n }\n toString() {\n return this.inspect();\n }\n toJSON() {\n return this.__value;\n }\n equals(other) {\n return this.extract() === other.extract();\n }\n map(_) {\n return nothing;\n }\n ap(_) {\n return nothing;\n }\n alt(other) {\n return other;\n }\n altLazy(other) {\n return other();\n }\n chain(_) {\n return nothing;\n }\n chainNullable(_) {\n return nothing;\n }\n join() {\n return nothing;\n }\n reduce(_, initialValue) {\n return initialValue;\n }\n extend(_) {\n return nothing;\n }\n unsafeCoerce() {\n throw new Error('Maybe#unsafeCoerce was ran on a Nothing');\n }\n caseOf(patterns) {\n return '_' in patterns ? patterns._() : patterns.Nothing();\n }\n orDefault(defaultValue) {\n return defaultValue;\n }\n orDefaultLazy(getDefaultValue) {\n return getDefaultValue();\n }\n toList() {\n return [];\n }\n mapOrDefault(_, defaultValue) {\n return defaultValue;\n }\n extract() {\n return undefined;\n }\n extractNullable() {\n return null;\n }\n toEither(left) {\n return Left(left);\n }\n ifJust(_) {\n return this;\n }\n ifNothing(effect) {\n return effect(), this;\n }\n filter(_) {\n return nothing;\n }\n}\nNothing.prototype['fantasy-land/equals'] = Nothing.prototype.equals;\nNothing.prototype['fantasy-land/map'] = Nothing.prototype.map;\nNothing.prototype['fantasy-land/ap'] = Nothing.prototype.ap;\nNothing.prototype['fantasy-land/alt'] = Nothing.prototype.alt;\nNothing.prototype['fantasy-land/chain'] = Nothing.prototype.chain;\nNothing.prototype['fantasy-land/reduce'] = Nothing.prototype.reduce;\nNothing.prototype['fantasy-land/extend'] = Nothing.prototype.extend;\nNothing.prototype['fantasy-land/filter'] = Nothing.prototype.filter;\nNothing.prototype.constructor = Maybe;\n/** Constructs a Just. Represents an optional value that exists */\nconst just = (value) => new Just(value);\n/** Represents a missing value, you can think of it as a smart 'null' */\nconst nothing = new Nothing();\nexport { just as Just, nothing as Nothing };\n","import { Just, Nothing } from './Maybe.js';\nexport const Either = {\n of(value) {\n return right(value);\n },\n lefts(list) {\n let result = [];\n for (const x of list) {\n if (x.isLeft()) {\n result.push(x.extract());\n }\n }\n return result;\n },\n rights(list) {\n let result = [];\n for (const x of list) {\n if (x.isRight()) {\n result.push(x.extract());\n }\n }\n return result;\n },\n encase(throwsF) {\n try {\n return right(throwsF());\n }\n catch (e) {\n return left(e);\n }\n },\n sequence(eithers) {\n let res = [];\n for (const e of eithers) {\n if (e.isLeft()) {\n return e;\n }\n res.push(e.extract());\n }\n return right(res);\n },\n isEither(x) {\n return x instanceof Left || x instanceof Right;\n },\n 'fantasy-land/of'(value) {\n return Either.of(value);\n }\n};\nclass Right {\n constructor(__value) {\n this.__value = __value;\n this._ = 'R';\n }\n isLeft() {\n return false;\n }\n isRight() {\n return true;\n }\n toJSON() {\n return this.__value;\n }\n inspect() {\n return `Right(${this.__value})`;\n }\n [Symbol.for('nodejs.util.inspect.custom')](_depth, opts, inspect) {\n return `Right(${inspect(this.__value, opts)})`;\n }\n toString() {\n return this.inspect();\n }\n bimap(_, g) {\n return right(g(this.__value));\n }\n map(f) {\n return right(f(this.__value));\n }\n mapLeft(_) {\n return this;\n }\n ap(other) {\n return other.isRight() ? this.map(other.extract()) : other;\n }\n equals(other) {\n return other.isRight() ? this.__value === other.extract() : false;\n }\n chain(f) {\n return f(this.__value);\n }\n chainLeft(_) {\n return this;\n }\n join() {\n return this.__value;\n }\n alt(_) {\n return this;\n }\n altLazy(_) {\n return this;\n }\n reduce(reducer, initialValue) {\n return reducer(initialValue, this.__value);\n }\n extend(f) {\n return right(f(this));\n }\n unsafeCoerce() {\n return this.__value;\n }\n caseOf(patterns) {\n return '_' in patterns ? patterns._() : patterns.Right(this.__value);\n }\n leftOrDefault(defaultValue) {\n return defaultValue;\n }\n orDefault(_) {\n return this.__value;\n }\n orDefaultLazy(_) {\n return this.__value;\n }\n leftOrDefaultLazy(getDefaultValue) {\n return getDefaultValue();\n }\n ifLeft(_) {\n return this;\n }\n ifRight(effect) {\n return effect(this.__value), this;\n }\n toMaybe() {\n return Just(this.__value);\n }\n leftToMaybe() {\n return Nothing;\n }\n extract() {\n return this.__value;\n }\n swap() {\n return left(this.__value);\n }\n}\nRight.prototype['fantasy-land/bimap'] = Right.prototype.bimap;\nRight.prototype['fantasy-land/map'] = Right.prototype.map;\nRight.prototype['fantasy-land/ap'] = Right.prototype.ap;\nRight.prototype['fantasy-land/equals'] = Right.prototype.equals;\nRight.prototype['fantasy-land/chain'] = Right.prototype.chain;\nRight.prototype['fantasy-land/alt'] = Right.prototype.alt;\nRight.prototype['fantasy-land/reduce'] = Right.prototype.reduce;\nRight.prototype['fantasy-land/extend'] = Right.prototype.extend;\nRight.prototype.constructor = Either;\nclass Left {\n constructor(__value) {\n this.__value = __value;\n this._ = 'L';\n }\n isLeft() {\n return true;\n }\n isRight() {\n return false;\n }\n toJSON() {\n return this.__value;\n }\n inspect() {\n return `Left(${JSON.stringify(this.__value)})`;\n }\n [Symbol.for('nodejs.util.inspect.custom')](_depth, opts, inspect) {\n return `Left(${inspect(this.__value, opts)})`;\n }\n toString() {\n return this.inspect();\n }\n bimap(f, _) {\n return left(f(this.__value));\n }\n map(_) {\n return this;\n }\n mapLeft(f) {\n return left(f(this.__value));\n }\n ap(other) {\n return other.isLeft() ? other : this;\n }\n equals(other) {\n return other.isLeft() ? other.extract() === this.__value : false;\n }\n chain(_) {\n return this;\n }\n chainLeft(f) {\n return f(this.__value);\n }\n join() {\n return this;\n }\n alt(other) {\n return other;\n }\n altLazy(other) {\n return other();\n }\n reduce(_, initialValue) {\n return initialValue;\n }\n extend(_) {\n return this;\n }\n unsafeCoerce() {\n if (this.__value instanceof Error) {\n throw this.__value;\n }\n throw new Error('Either#unsafeCoerce was ran on a Left');\n }\n caseOf(patterns) {\n return '_' in patterns ? patterns._() : patterns.Left(this.__value);\n }\n leftOrDefault(_) {\n return this.__value;\n }\n orDefault(defaultValue) {\n return defaultValue;\n }\n orDefaultLazy(getDefaultValue) {\n return getDefaultValue();\n }\n leftOrDefaultLazy(_) {\n return this.__value;\n }\n ifLeft(effect) {\n return effect(this.__value), this;\n }\n ifRight(_) {\n return this;\n }\n toMaybe() {\n return Nothing;\n }\n leftToMaybe() {\n return Just(this.__value);\n }\n extract() {\n return this.__value;\n }\n swap() {\n return right(this.__value);\n }\n}\nLeft.prototype['fantasy-land/bimap'] = Left.prototype.bimap;\nLeft.prototype['fantasy-land/map'] = Left.prototype.map;\nLeft.prototype['fantasy-land/ap'] = Left.prototype.ap;\nLeft.prototype['fantasy-land/equals'] = Left.prototype.equals;\nLeft.prototype['fantasy-land/chain'] = Left.prototype.chain;\nLeft.prototype['fantasy-land/alt'] = Left.prototype.alt;\nLeft.prototype['fantasy-land/reduce'] = Left.prototype.reduce;\nLeft.prototype['fantasy-land/extend'] = Left.prototype.extend;\nLeft.prototype.constructor = Either;\nconst left = (value) => new Left(value);\nconst right = (value) => new Right(value);\nexport { left as Left, right as Right };\n","/** The identity function, returns the value it was given */\nexport const identity = (x) => x;\n/** Returns a function that always returns the same value. Also known as `const` in other languages */\nexport const always = (x) => () => x;\nexport const Order = {\n LT: 'LT',\n EQ: 'EQ',\n GT: 'GT'\n};\n/** Compares two values using the default \"<\" and \">\" operators */\nexport const compare = (x, y) => {\n if (x > y) {\n return Order.GT;\n }\n else if (x < y) {\n return Order.LT;\n }\n else {\n return Order.EQ;\n }\n};\n/** Maps the Order enum to the values expected by the standard ECMAScript library when doing comparison (Array.prototype.sort, for example) */\nexport const orderToNumber = (order) => {\n switch (order) {\n case Order.LT:\n return -1;\n case Order.EQ:\n return 0;\n case Order.GT:\n return 1;\n }\n};\n/** Takes a function that receives multiple arguments and returns a \"curried\" version of that function that can take any number of those arguments and if they are less than needed a new function that takes the rest of them will be returned */\nexport const curry = (fn) => function currify(...args) {\n return args.length >= fn.length\n ? fn.apply(undefined, args)\n : currify.bind(undefined, ...args);\n};\n","/** Fonctions pour la création de simples animations JavaScript. */\n\nimport { ATTRIBUT_CHARGEMENT } from \"../constantes/dom\";\n\n// Types\ninterface AnimationCycleTexte {\n callback: () => void;\n etapes: Array;\n index: number;\n interval: NodeJS.Timeout;\n}\n\ninterface ParametresAnimationCycleTexte {\n attribut: string;\n element: HTMLElement;\n etapes: Array;\n}\n\n/**\n * Créer le nécessaire pour une animation s'exécutant jusqu'à ce que un interval soit manuellement arrêté. L'animation\n * consiste en la mise à jour d'un texte avec l'utilisation de toutes les valeurs d'un tableau, une par une.\n *\n * @param args Les paramètres nécessaires pour la création de l'animation.\n * @returns Un objet contenant les informations de l'animation, notamment l'interval utilisable pour son arrêt.\n */\nconst lanceAnimationCycleTexte = (args: ParametresAnimationCycleTexte): AnimationCycleTexte => {\n const animation: AnimationCycleTexte = {\n callback: (): void => {\n // Arrête le cycle quand l'Attribut de chargement n'est plus présent\n if (!args.element.hasAttribute(args.attribut)) {\n clearInterval(animation.interval);\n return;\n }\n\n // Change le texte\n args.element.textContent = animation.etapes.at(animation.index) ?? \"Loading...\";\n // Incrémente ou réinitialise l'index\n animation.index = animation.index + 1 > animation.etapes.length - 1 ? 0 : animation.index + 1;\n },\n etapes: args.etapes,\n index: 0,\n interval: setInterval(() => {}, 2147483647),\n };\n\n return animation;\n};\n\nexport const lanceAnimationCycleLoading = (element: HTMLElement, delai: number): void => {\n const animation = lanceAnimationCycleTexte({\n attribut: ATTRIBUT_CHARGEMENT,\n element: element,\n etapes: [\n \"Loading\",\n \"Loading.\",\n \"Loading..\",\n \"Loading...\",\n ],\n });\n animation.callback();\n animation.interval = setInterval(animation.callback, delai);\n};\n","// src/storages/globalConfig/globalConfig.ts\nvar store;\nfunction setGlobalConfig(config2) {\n store = { ...store, ...config2 };\n}\n// @__NO_SIDE_EFFECTS__\nfunction getGlobalConfig(config2) {\n return {\n lang: config2?.lang ?? store?.lang,\n message: config2?.message,\n abortEarly: config2?.abortEarly ?? store?.abortEarly,\n abortPipeEarly: config2?.abortPipeEarly ?? store?.abortPipeEarly\n };\n}\nfunction deleteGlobalConfig() {\n store = void 0;\n}\n\n// src/storages/globalMessage/globalMessage.ts\nvar store2;\nfunction setGlobalMessage(message2, lang) {\n if (!store2) store2 = /* @__PURE__ */ new Map();\n store2.set(lang, message2);\n}\n// @__NO_SIDE_EFFECTS__\nfunction getGlobalMessage(lang) {\n return store2?.get(lang);\n}\nfunction deleteGlobalMessage(lang) {\n store2?.delete(lang);\n}\n\n// src/storages/schemaMessage/schemaMessage.ts\nvar store3;\nfunction setSchemaMessage(message2, lang) {\n if (!store3) store3 = /* @__PURE__ */ new Map();\n store3.set(lang, message2);\n}\n// @__NO_SIDE_EFFECTS__\nfunction getSchemaMessage(lang) {\n return store3?.get(lang);\n}\nfunction deleteSchemaMessage(lang) {\n store3?.delete(lang);\n}\n\n// src/storages/specificMessage/specificMessage.ts\nvar store4;\nfunction setSpecificMessage(reference, message2, lang) {\n if (!store4) store4 = /* @__PURE__ */ new Map();\n if (!store4.get(reference)) store4.set(reference, /* @__PURE__ */ new Map());\n store4.get(reference).set(lang, message2);\n}\n// @__NO_SIDE_EFFECTS__\nfunction getSpecificMessage(reference, lang) {\n return store4?.get(reference)?.get(lang);\n}\nfunction deleteSpecificMessage(reference, lang) {\n store4?.get(reference)?.delete(lang);\n}\n\n// src/utils/_stringify/_stringify.ts\n// @__NO_SIDE_EFFECTS__\nfunction _stringify(input) {\n const type = typeof input;\n if (type === \"string\") {\n return `\"${input}\"`;\n }\n if (type === \"number\" || type === \"bigint\" || type === \"boolean\") {\n return `${input}`;\n }\n if (type === \"object\" || type === \"function\") {\n return (input && Object.getPrototypeOf(input)?.constructor?.name) ?? \"null\";\n }\n return type;\n}\n\n// src/utils/_addIssue/_addIssue.ts\nfunction _addIssue(context, label, dataset, config2, other) {\n const input = other && \"input\" in other ? other.input : dataset.value;\n const expected = other?.expected ?? context.expects ?? null;\n const received = other?.received ?? _stringify(input);\n const issue = {\n kind: context.kind,\n type: context.type,\n input,\n expected,\n received,\n message: `Invalid ${label}: ${expected ? `Expected ${expected} but r` : \"R\"}eceived ${received}`,\n requirement: context.requirement,\n path: other?.path,\n issues: other?.issues,\n lang: config2.lang,\n abortEarly: config2.abortEarly,\n abortPipeEarly: config2.abortPipeEarly\n };\n const isSchema = context.kind === \"schema\";\n const message2 = other?.message ?? context.message ?? getSpecificMessage(context.reference, issue.lang) ?? (isSchema ? getSchemaMessage(issue.lang) : null) ?? config2.message ?? getGlobalMessage(issue.lang);\n if (message2 !== void 0) {\n issue.message = typeof message2 === \"function\" ? (\n // @ts-expect-error\n message2(issue)\n ) : message2;\n }\n if (isSchema) {\n dataset.typed = false;\n }\n if (dataset.issues) {\n dataset.issues.push(issue);\n } else {\n dataset.issues = [issue];\n }\n}\n\n// src/utils/_getByteCount/_getByteCount.ts\nvar textEncoder;\n// @__NO_SIDE_EFFECTS__\nfunction _getByteCount(input) {\n if (!textEncoder) {\n textEncoder = new TextEncoder();\n }\n return textEncoder.encode(input).length;\n}\n\n// src/utils/_getGraphemeCount/_getGraphemeCount.ts\nvar segmenter;\n// @__NO_SIDE_EFFECTS__\nfunction _getGraphemeCount(input) {\n if (!segmenter) {\n segmenter = new Intl.Segmenter();\n }\n const segments = segmenter.segment(input);\n let count = 0;\n for (const _ of segments) {\n count++;\n }\n return count;\n}\n\n// src/utils/_getLastMetadata/_getLastMetadata.ts\n// @__NO_SIDE_EFFECTS__\nfunction _getLastMetadata(schema, type) {\n if (\"pipe\" in schema) {\n const nestedSchemas = [];\n for (let index = schema.pipe.length - 1; index >= 0; index--) {\n const item = schema.pipe[index];\n if (item.kind === \"schema\" && \"pipe\" in item) {\n nestedSchemas.push(item);\n } else if (item.kind === \"metadata\" && item.type === type) {\n return item[type];\n }\n }\n for (const nestedSchema of nestedSchemas) {\n const result = /* @__PURE__ */ _getLastMetadata(nestedSchema, type);\n if (result !== void 0) {\n return result;\n }\n }\n }\n}\n\n// src/utils/_getStandardProps/_getStandardProps.ts\n// @__NO_SIDE_EFFECTS__\nfunction _getStandardProps(context) {\n return {\n version: 1,\n vendor: \"valibot\",\n validate(value2) {\n return context[\"~run\"]({ value: value2 }, getGlobalConfig());\n }\n };\n}\n\n// src/utils/_getWordCount/_getWordCount.ts\nvar store5;\n// @__NO_SIDE_EFFECTS__\nfunction _getWordCount(locales, input) {\n if (!store5) {\n store5 = /* @__PURE__ */ new Map();\n }\n if (!store5.get(locales)) {\n store5.set(locales, new Intl.Segmenter(locales, { granularity: \"word\" }));\n }\n const segments = store5.get(locales).segment(input);\n let count = 0;\n for (const segment of segments) {\n if (segment.isWordLike) {\n count++;\n }\n }\n return count;\n}\n\n// src/utils/_isLuhnAlgo/_isLuhnAlgo.ts\nvar NON_DIGIT_REGEX = /\\D/gu;\n// @__NO_SIDE_EFFECTS__\nfunction _isLuhnAlgo(input) {\n const number2 = input.replace(NON_DIGIT_REGEX, \"\");\n let length2 = number2.length;\n let bit = 1;\n let sum = 0;\n while (length2) {\n const value2 = +number2[--length2];\n bit ^= 1;\n sum += bit ? [0, 2, 4, 6, 8, 1, 3, 5, 7, 9][value2] : value2;\n }\n return sum % 10 === 0;\n}\n\n// src/utils/_isValidObjectKey/_isValidObjectKey.ts\n// @__NO_SIDE_EFFECTS__\nfunction _isValidObjectKey(object2, key) {\n return Object.hasOwn(object2, key) && key !== \"__proto__\" && key !== \"prototype\" && key !== \"constructor\";\n}\n\n// src/utils/_joinExpects/_joinExpects.ts\n// @__NO_SIDE_EFFECTS__\nfunction _joinExpects(values2, separator) {\n const list = [...new Set(values2)];\n if (list.length > 1) {\n return `(${list.join(` ${separator} `)})`;\n }\n return list[0] ?? \"never\";\n}\n\n// src/utils/entriesFromList/entriesFromList.ts\n// @__NO_SIDE_EFFECTS__\nfunction entriesFromList(list, schema) {\n const entries2 = {};\n for (const key of list) {\n entries2[key] = schema;\n }\n return entries2;\n}\n\n// src/utils/entriesFromObjects/entriesFromObjects.ts\n// @__NO_SIDE_EFFECTS__\nfunction entriesFromObjects(schemas) {\n const entries2 = {};\n for (const schema of schemas) {\n Object.assign(entries2, schema.entries);\n }\n return entries2;\n}\n\n// src/utils/getDotPath/getDotPath.ts\n// @__NO_SIDE_EFFECTS__\nfunction getDotPath(issue) {\n if (issue.path) {\n let key = \"\";\n for (const item of issue.path) {\n if (typeof item.key === \"string\" || typeof item.key === \"number\") {\n if (key) {\n key += `.${item.key}`;\n } else {\n key += item.key;\n }\n } else {\n return null;\n }\n }\n return key;\n }\n return null;\n}\n\n// src/utils/isOfKind/isOfKind.ts\n// @__NO_SIDE_EFFECTS__\nfunction isOfKind(kind, object2) {\n return object2.kind === kind;\n}\n\n// src/utils/isOfType/isOfType.ts\n// @__NO_SIDE_EFFECTS__\nfunction isOfType(type, object2) {\n return object2.type === type;\n}\n\n// src/utils/isValiError/isValiError.ts\n// @__NO_SIDE_EFFECTS__\nfunction isValiError(error) {\n return error instanceof ValiError;\n}\n\n// src/utils/ValiError/ValiError.ts\nvar ValiError = class extends Error {\n /**\n * Creates a Valibot error with useful information.\n *\n * @param issues The error issues.\n */\n constructor(issues) {\n super(issues[0].message);\n this.name = \"ValiError\";\n this.issues = issues;\n }\n};\n\n// src/actions/args/args.ts\n// @__NO_SIDE_EFFECTS__\nfunction args(schema) {\n return {\n kind: \"transformation\",\n type: \"args\",\n reference: args,\n async: false,\n schema,\n \"~run\"(dataset, config2) {\n const func = dataset.value;\n dataset.value = (...args_) => {\n const argsDataset = this.schema[\"~run\"]({ value: args_ }, config2);\n if (argsDataset.issues) {\n throw new ValiError(argsDataset.issues);\n }\n return func(...argsDataset.value);\n };\n return dataset;\n }\n };\n}\n\n// src/actions/args/argsAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction argsAsync(schema) {\n return {\n kind: \"transformation\",\n type: \"args\",\n reference: argsAsync,\n async: false,\n schema,\n \"~run\"(dataset, config2) {\n const func = dataset.value;\n dataset.value = async (...args2) => {\n const argsDataset = await schema[\"~run\"]({ value: args2 }, config2);\n if (argsDataset.issues) {\n throw new ValiError(argsDataset.issues);\n }\n return func(...argsDataset.value);\n };\n return dataset;\n }\n };\n}\n\n// src/actions/await/awaitAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction awaitAsync() {\n return {\n kind: \"transformation\",\n type: \"await\",\n reference: awaitAsync,\n async: true,\n async \"~run\"(dataset) {\n dataset.value = await dataset.value;\n return dataset;\n }\n };\n}\n\n// src/regex.ts\nvar BASE64_REGEX = /^(?:[\\da-z+/]{4})*(?:[\\da-z+/]{2}==|[\\da-z+/]{3}=)?$/iu;\nvar BIC_REGEX = /^[A-Z]{6}(?!00)[\\dA-Z]{2}(?:[\\dA-Z]{3})?$/u;\nvar CUID2_REGEX = /^[a-z][\\da-z]*$/u;\nvar DECIMAL_REGEX = /^[+-]?(?:\\d*\\.)?\\d+$/u;\nvar DIGITS_REGEX = /^\\d+$/u;\nvar EMAIL_REGEX = /^[\\w+-]+(?:\\.[\\w+-]+)*@[\\da-z]+(?:[.-][\\da-z]+)*\\.[a-z]{2,}$/iu;\nvar EMOJI_REGEX = (\n // eslint-disable-next-line redos-detector/no-unsafe-regex, regexp/no-dupe-disjunctions -- false positives\n /^(?:[\\u{1F1E6}-\\u{1F1FF}]{2}|\\u{1F3F4}[\\u{E0061}-\\u{E007A}]{2}[\\u{E0030}-\\u{E0039}\\u{E0061}-\\u{E007A}]{1,3}\\u{E007F}|(?:\\p{Emoji}\\uFE0F\\u20E3?|\\p{Emoji_Modifier_Base}\\p{Emoji_Modifier}?|\\p{Emoji_Presentation})(?:\\u200D(?:\\p{Emoji}\\uFE0F\\u20E3?|\\p{Emoji_Modifier_Base}\\p{Emoji_Modifier}?|\\p{Emoji_Presentation}))*)+$/u\n);\nvar HEXADECIMAL_REGEX = /^(?:0[hx])?[\\da-fA-F]+$/u;\nvar HEX_COLOR_REGEX = /^#(?:[\\da-fA-F]{3,4}|[\\da-fA-F]{6}|[\\da-fA-F]{8})$/u;\nvar IMEI_REGEX = /^\\d{15}$|^\\d{2}-\\d{6}-\\d{6}-\\d$/u;\nvar IPV4_REGEX = (\n // eslint-disable-next-line redos-detector/no-unsafe-regex -- false positive\n /^(?:(?:[1-9]|1\\d|2[0-4])?\\d|25[0-5])(?:\\.(?:(?:[1-9]|1\\d|2[0-4])?\\d|25[0-5])){3}$/u\n);\nvar IPV6_REGEX = /^(?:(?:[\\da-f]{1,4}:){7}[\\da-f]{1,4}|(?:[\\da-f]{1,4}:){1,7}:|(?:[\\da-f]{1,4}:){1,6}:[\\da-f]{1,4}|(?:[\\da-f]{1,4}:){1,5}(?::[\\da-f]{1,4}){1,2}|(?:[\\da-f]{1,4}:){1,4}(?::[\\da-f]{1,4}){1,3}|(?:[\\da-f]{1,4}:){1,3}(?::[\\da-f]{1,4}){1,4}|(?:[\\da-f]{1,4}:){1,2}(?::[\\da-f]{1,4}){1,5}|[\\da-f]{1,4}:(?::[\\da-f]{1,4}){1,6}|:(?:(?::[\\da-f]{1,4}){1,7}|:)|fe80:(?::[\\da-f]{0,4}){0,4}%[\\da-z]+|::(?:f{4}(?::0{1,4})?:)?(?:(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d)\\.){3}(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d)|(?:[\\da-f]{1,4}:){1,4}:(?:(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d)\\.){3}(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d))$/iu;\nvar IP_REGEX = /^(?:(?:[1-9]|1\\d|2[0-4])?\\d|25[0-5])(?:\\.(?:(?:[1-9]|1\\d|2[0-4])?\\d|25[0-5])){3}$|^(?:(?:[\\da-f]{1,4}:){7}[\\da-f]{1,4}|(?:[\\da-f]{1,4}:){1,7}:|(?:[\\da-f]{1,4}:){1,6}:[\\da-f]{1,4}|(?:[\\da-f]{1,4}:){1,5}(?::[\\da-f]{1,4}){1,2}|(?:[\\da-f]{1,4}:){1,4}(?::[\\da-f]{1,4}){1,3}|(?:[\\da-f]{1,4}:){1,3}(?::[\\da-f]{1,4}){1,4}|(?:[\\da-f]{1,4}:){1,2}(?::[\\da-f]{1,4}){1,5}|[\\da-f]{1,4}:(?::[\\da-f]{1,4}){1,6}|:(?:(?::[\\da-f]{1,4}){1,7}|:)|fe80:(?::[\\da-f]{0,4}){0,4}%[\\da-z]+|::(?:f{4}(?::0{1,4})?:)?(?:(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d)\\.){3}(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d)|(?:[\\da-f]{1,4}:){1,4}:(?:(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d)\\.){3}(?:25[0-5]|(?:2[0-4]|1?\\d)?\\d))$/iu;\nvar ISO_DATE_REGEX = /^\\d{4}-(?:0[1-9]|1[0-2])-(?:[12]\\d|0[1-9]|3[01])$/u;\nvar ISO_DATE_TIME_REGEX = /^\\d{4}-(?:0[1-9]|1[0-2])-(?:[12]\\d|0[1-9]|3[01])[T ](?:0\\d|1\\d|2[0-3]):[0-5]\\d$/u;\nvar ISO_TIME_REGEX = /^(?:0\\d|1\\d|2[0-3]):[0-5]\\d$/u;\nvar ISO_TIME_SECOND_REGEX = /^(?:0\\d|1\\d|2[0-3])(?::[0-5]\\d){2}$/u;\nvar ISO_TIMESTAMP_REGEX = /^\\d{4}-(?:0[1-9]|1[0-2])-(?:[12]\\d|0[1-9]|3[01])[T ](?:0\\d|1\\d|2[0-3])(?::[0-5]\\d){2}(?:\\.\\d{1,9})?(?:Z|[+-](?:0\\d|1\\d|2[0-3])(?::?[0-5]\\d)?)$/u;\nvar ISO_WEEK_REGEX = /^\\d{4}-W(?:0[1-9]|[1-4]\\d|5[0-3])$/u;\nvar MAC48_REGEX = /^(?:[\\da-f]{2}:){5}[\\da-f]{2}$|^(?:[\\da-f]{2}-){5}[\\da-f]{2}$|^(?:[\\da-f]{4}\\.){2}[\\da-f]{4}$/iu;\nvar MAC64_REGEX = /^(?:[\\da-f]{2}:){7}[\\da-f]{2}$|^(?:[\\da-f]{2}-){7}[\\da-f]{2}$|^(?:[\\da-f]{4}\\.){3}[\\da-f]{4}$|^(?:[\\da-f]{4}:){3}[\\da-f]{4}$/iu;\nvar MAC_REGEX = /^(?:[\\da-f]{2}:){5}[\\da-f]{2}$|^(?:[\\da-f]{2}-){5}[\\da-f]{2}$|^(?:[\\da-f]{4}\\.){2}[\\da-f]{4}$|^(?:[\\da-f]{2}:){7}[\\da-f]{2}$|^(?:[\\da-f]{2}-){7}[\\da-f]{2}$|^(?:[\\da-f]{4}\\.){3}[\\da-f]{4}$|^(?:[\\da-f]{4}:){3}[\\da-f]{4}$/iu;\nvar NANO_ID_REGEX = /^[\\w-]+$/u;\nvar OCTAL_REGEX = /^(?:0o)?[0-7]+$/u;\nvar RFC_EMAIL_REGEX = (\n // eslint-disable-next-line regexp/prefer-w, no-useless-escape, regexp/no-useless-escape, regexp/require-unicode-regexp\n /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/\n);\nvar SLUG_REGEX = /^[\\da-z]+(?:[-_][\\da-z]+)*$/u;\nvar ULID_REGEX = /^[\\da-hjkmnp-tv-zA-HJKMNP-TV-Z]{26}$/u;\nvar UUID_REGEX = /^[\\da-f]{8}(?:-[\\da-f]{4}){3}-[\\da-f]{12}$/iu;\n\n// src/actions/base64/base64.ts\n// @__NO_SIDE_EFFECTS__\nfunction base64(message2) {\n return {\n kind: \"validation\",\n type: \"base64\",\n reference: base64,\n async: false,\n expects: null,\n requirement: BASE64_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"Base64\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/bic/bic.ts\n// @__NO_SIDE_EFFECTS__\nfunction bic(message2) {\n return {\n kind: \"validation\",\n type: \"bic\",\n reference: bic,\n async: false,\n expects: null,\n requirement: BIC_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"BIC\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/brand/brand.ts\n// @__NO_SIDE_EFFECTS__\nfunction brand(name) {\n return {\n kind: \"transformation\",\n type: \"brand\",\n reference: brand,\n async: false,\n name,\n \"~run\"(dataset) {\n return dataset;\n }\n };\n}\n\n// src/actions/bytes/bytes.ts\n// @__NO_SIDE_EFFECTS__\nfunction bytes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"bytes\",\n reference: bytes,\n async: false,\n expects: `${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const length2 = _getByteCount(dataset.value);\n if (length2 !== this.requirement) {\n _addIssue(this, \"bytes\", dataset, config2, {\n received: `${length2}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/check/check.ts\n// @__NO_SIDE_EFFECTS__\nfunction check(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"check\",\n reference: check,\n async: false,\n expects: null,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement(dataset.value)) {\n _addIssue(this, \"input\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/check/checkAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction checkAsync(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"check\",\n reference: checkAsync,\n async: true,\n expects: null,\n requirement,\n message: message2,\n async \"~run\"(dataset, config2) {\n if (dataset.typed && !await this.requirement(dataset.value)) {\n _addIssue(this, \"input\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/checkItems/checkItems.ts\n// @__NO_SIDE_EFFECTS__\nfunction checkItems(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"check_items\",\n reference: checkItems,\n async: false,\n expects: null,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n for (let index = 0; index < dataset.value.length; index++) {\n const item = dataset.value[index];\n if (!this.requirement(item, index, dataset.value)) {\n _addIssue(this, \"item\", dataset, config2, {\n input: item,\n path: [\n {\n type: \"array\",\n origin: \"value\",\n input: dataset.value,\n key: index,\n value: item\n }\n ]\n });\n }\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/checkItems/checkItemsAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction checkItemsAsync(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"check_items\",\n reference: checkItemsAsync,\n async: true,\n expects: null,\n requirement,\n message: message2,\n async \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const requirementResults = await Promise.all(\n dataset.value.map(this.requirement)\n );\n for (let index = 0; index < dataset.value.length; index++) {\n if (!requirementResults[index]) {\n const item = dataset.value[index];\n _addIssue(this, \"item\", dataset, config2, {\n input: item,\n path: [\n {\n type: \"array\",\n origin: \"value\",\n input: dataset.value,\n key: index,\n value: item\n }\n ]\n });\n }\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/creditCard/creditCard.ts\nvar CREDIT_CARD_REGEX = /^(?:\\d{14,19}|\\d{4}(?: \\d{3,6}){2,4}|\\d{4}(?:-\\d{3,6}){2,4})$/u;\nvar SANITIZE_REGEX = /[- ]/gu;\nvar PROVIDER_REGEX_LIST = [\n // American Express\n /^3[47]\\d{13}$/u,\n // Diners Club\n /^3(?:0[0-5]|[68]\\d)\\d{11,13}$/u,\n // Discover\n /^6(?:011|5\\d{2})\\d{12,15}$/u,\n // JCB\n /^(?:2131|1800|35\\d{3})\\d{11}$/u,\n // Mastercard\n // eslint-disable-next-line redos-detector/no-unsafe-regex\n /^5[1-5]\\d{2}|(?:222\\d|22[3-9]\\d|2[3-6]\\d{2}|27[01]\\d|2720)\\d{12}$/u,\n // UnionPay\n /^(?:6[27]\\d{14,17}|81\\d{14,17})$/u,\n // Visa\n /^4\\d{12}(?:\\d{3,6})?$/u\n];\n// @__NO_SIDE_EFFECTS__\nfunction creditCard(message2) {\n return {\n kind: \"validation\",\n type: \"credit_card\",\n reference: creditCard,\n async: false,\n expects: null,\n requirement(input) {\n let sanitized;\n return CREDIT_CARD_REGEX.test(input) && // Remove any hyphens and blanks\n (sanitized = input.replace(SANITIZE_REGEX, \"\")) && // Check if it matches a provider\n PROVIDER_REGEX_LIST.some((regex2) => regex2.test(sanitized)) && // Check if passes luhn algorithm\n _isLuhnAlgo(sanitized);\n },\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement(dataset.value)) {\n _addIssue(this, \"credit card\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/cuid2/cuid2.ts\n// @__NO_SIDE_EFFECTS__\nfunction cuid2(message2) {\n return {\n kind: \"validation\",\n type: \"cuid2\",\n reference: cuid2,\n async: false,\n expects: null,\n requirement: CUID2_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"Cuid2\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/decimal/decimal.ts\n// @__NO_SIDE_EFFECTS__\nfunction decimal(message2) {\n return {\n kind: \"validation\",\n type: \"decimal\",\n reference: decimal,\n async: false,\n expects: null,\n requirement: DECIMAL_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"decimal\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/description/description.ts\n// @__NO_SIDE_EFFECTS__\nfunction description(description_) {\n return {\n kind: \"metadata\",\n type: \"description\",\n reference: description,\n description: description_\n };\n}\n\n// src/actions/digits/digits.ts\n// @__NO_SIDE_EFFECTS__\nfunction digits(message2) {\n return {\n kind: \"validation\",\n type: \"digits\",\n reference: digits,\n async: false,\n expects: null,\n requirement: DIGITS_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"digits\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/email/email.ts\n// @__NO_SIDE_EFFECTS__\nfunction email(message2) {\n return {\n kind: \"validation\",\n type: \"email\",\n reference: email,\n expects: null,\n async: false,\n requirement: EMAIL_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"email\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/emoji/emoji.ts\n// @__NO_SIDE_EFFECTS__\nfunction emoji(message2) {\n return {\n kind: \"validation\",\n type: \"emoji\",\n reference: emoji,\n async: false,\n expects: null,\n requirement: EMOJI_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"emoji\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/empty/empty.ts\n// @__NO_SIDE_EFFECTS__\nfunction empty(message2) {\n return {\n kind: \"validation\",\n type: \"empty\",\n reference: empty,\n async: false,\n expects: \"0\",\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.length > 0) {\n _addIssue(this, \"length\", dataset, config2, {\n received: `${dataset.value.length}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/endsWith/endsWith.ts\n// @__NO_SIDE_EFFECTS__\nfunction endsWith(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"ends_with\",\n reference: endsWith,\n async: false,\n expects: `\"${requirement}\"`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !dataset.value.endsWith(this.requirement)) {\n _addIssue(this, \"end\", dataset, config2, {\n received: `\"${dataset.value.slice(-this.requirement.length)}\"`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/entries/entries.ts\n// @__NO_SIDE_EFFECTS__\nfunction entries(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"entries\",\n reference: entries,\n async: false,\n expects: `${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (!dataset.typed) return dataset;\n const count = Object.keys(dataset.value).length;\n if (dataset.typed && count !== this.requirement) {\n _addIssue(this, \"entries\", dataset, config2, {\n received: `${count}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/everyItem/everyItem.ts\n// @__NO_SIDE_EFFECTS__\nfunction everyItem(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"every_item\",\n reference: everyItem,\n async: false,\n expects: null,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !dataset.value.every(this.requirement)) {\n _addIssue(this, \"item\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/excludes/excludes.ts\n// @__NO_SIDE_EFFECTS__\nfunction excludes(requirement, message2) {\n const received = _stringify(requirement);\n return {\n kind: \"validation\",\n type: \"excludes\",\n reference: excludes,\n async: false,\n expects: `!${received}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.includes(this.requirement)) {\n _addIssue(this, \"content\", dataset, config2, { received });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/filterItems/filterItems.ts\n// @__NO_SIDE_EFFECTS__\nfunction filterItems(operation) {\n return {\n kind: \"transformation\",\n type: \"filter_items\",\n reference: filterItems,\n async: false,\n operation,\n \"~run\"(dataset) {\n dataset.value = dataset.value.filter(this.operation);\n return dataset;\n }\n };\n}\n\n// src/actions/findItem/findItem.ts\n// @__NO_SIDE_EFFECTS__\nfunction findItem(operation) {\n return {\n kind: \"transformation\",\n type: \"find_item\",\n reference: findItem,\n async: false,\n operation,\n \"~run\"(dataset) {\n dataset.value = dataset.value.find(this.operation);\n return dataset;\n }\n };\n}\n\n// src/actions/finite/finite.ts\n// @__NO_SIDE_EFFECTS__\nfunction finite(message2) {\n return {\n kind: \"validation\",\n type: \"finite\",\n reference: finite,\n async: false,\n expects: null,\n requirement: Number.isFinite,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement(dataset.value)) {\n _addIssue(this, \"finite\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/flavor/flavor.ts\n// @__NO_SIDE_EFFECTS__\nfunction flavor(name) {\n return {\n kind: \"transformation\",\n type: \"flavor\",\n reference: flavor,\n async: false,\n name,\n \"~run\"(dataset) {\n return dataset;\n }\n };\n}\n\n// src/actions/graphemes/graphemes.ts\n// @__NO_SIDE_EFFECTS__\nfunction graphemes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"graphemes\",\n reference: graphemes,\n async: false,\n expects: `${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getGraphemeCount(dataset.value);\n if (count !== this.requirement) {\n _addIssue(this, \"graphemes\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/gtValue/gtValue.ts\n// @__NO_SIDE_EFFECTS__\nfunction gtValue(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"gt_value\",\n reference: gtValue,\n async: false,\n expects: `>${requirement instanceof Date ? requirement.toJSON() : _stringify(requirement)}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !(dataset.value > this.requirement)) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/hash/hash.ts\nvar HASH_LENGTHS = {\n md4: 32,\n md5: 32,\n sha1: 40,\n sha256: 64,\n sha384: 96,\n sha512: 128,\n ripemd128: 32,\n ripemd160: 40,\n tiger128: 32,\n tiger160: 40,\n tiger192: 48,\n crc32: 8,\n crc32b: 8,\n adler32: 8\n};\n// @__NO_SIDE_EFFECTS__\nfunction hash(types, message2) {\n return {\n kind: \"validation\",\n type: \"hash\",\n reference: hash,\n expects: null,\n async: false,\n requirement: RegExp(\n types.map((type) => `^[a-f0-9]{${HASH_LENGTHS[type]}}$`).join(\"|\"),\n \"iu\"\n ),\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"hash\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/hexadecimal/hexadecimal.ts\n// @__NO_SIDE_EFFECTS__\nfunction hexadecimal(message2) {\n return {\n kind: \"validation\",\n type: \"hexadecimal\",\n reference: hexadecimal,\n async: false,\n expects: null,\n requirement: HEXADECIMAL_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"hexadecimal\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/hexColor/hexColor.ts\n// @__NO_SIDE_EFFECTS__\nfunction hexColor(message2) {\n return {\n kind: \"validation\",\n type: \"hex_color\",\n reference: hexColor,\n async: false,\n expects: null,\n requirement: HEX_COLOR_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"hex color\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/imei/imei.ts\n// @__NO_SIDE_EFFECTS__\nfunction imei(message2) {\n return {\n kind: \"validation\",\n type: \"imei\",\n reference: imei,\n async: false,\n expects: null,\n requirement(input) {\n return IMEI_REGEX.test(input) && _isLuhnAlgo(input);\n },\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement(dataset.value)) {\n _addIssue(this, \"IMEI\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/includes/includes.ts\n// @__NO_SIDE_EFFECTS__\nfunction includes(requirement, message2) {\n const expects = _stringify(requirement);\n return {\n kind: \"validation\",\n type: \"includes\",\n reference: includes,\n async: false,\n expects,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !dataset.value.includes(this.requirement)) {\n _addIssue(this, \"content\", dataset, config2, {\n received: `!${expects}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/integer/integer.ts\n// @__NO_SIDE_EFFECTS__\nfunction integer(message2) {\n return {\n kind: \"validation\",\n type: \"integer\",\n reference: integer,\n async: false,\n expects: null,\n requirement: Number.isInteger,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement(dataset.value)) {\n _addIssue(this, \"integer\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/ip/ip.ts\n// @__NO_SIDE_EFFECTS__\nfunction ip(message2) {\n return {\n kind: \"validation\",\n type: \"ip\",\n reference: ip,\n async: false,\n expects: null,\n requirement: IP_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"IP\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/ipv4/ipv4.ts\n// @__NO_SIDE_EFFECTS__\nfunction ipv4(message2) {\n return {\n kind: \"validation\",\n type: \"ipv4\",\n reference: ipv4,\n async: false,\n expects: null,\n requirement: IPV4_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"IPv4\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/ipv6/ipv6.ts\n// @__NO_SIDE_EFFECTS__\nfunction ipv6(message2) {\n return {\n kind: \"validation\",\n type: \"ipv6\",\n reference: ipv6,\n async: false,\n expects: null,\n requirement: IPV6_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"IPv6\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/isoDate/isoDate.ts\n// @__NO_SIDE_EFFECTS__\nfunction isoDate(message2) {\n return {\n kind: \"validation\",\n type: \"iso_date\",\n reference: isoDate,\n async: false,\n expects: null,\n requirement: ISO_DATE_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"date\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/isoDateTime/isoDateTime.ts\n// @__NO_SIDE_EFFECTS__\nfunction isoDateTime(message2) {\n return {\n kind: \"validation\",\n type: \"iso_date_time\",\n reference: isoDateTime,\n async: false,\n expects: null,\n requirement: ISO_DATE_TIME_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"date-time\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/isoTime/isoTime.ts\n// @__NO_SIDE_EFFECTS__\nfunction isoTime(message2) {\n return {\n kind: \"validation\",\n type: \"iso_time\",\n reference: isoTime,\n async: false,\n expects: null,\n requirement: ISO_TIME_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"time\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/isoTimeSecond/isoTimeSecond.ts\n// @__NO_SIDE_EFFECTS__\nfunction isoTimeSecond(message2) {\n return {\n kind: \"validation\",\n type: \"iso_time_second\",\n reference: isoTimeSecond,\n async: false,\n expects: null,\n requirement: ISO_TIME_SECOND_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"time-second\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/isoTimestamp/isoTimestamp.ts\n// @__NO_SIDE_EFFECTS__\nfunction isoTimestamp(message2) {\n return {\n kind: \"validation\",\n type: \"iso_timestamp\",\n reference: isoTimestamp,\n async: false,\n expects: null,\n requirement: ISO_TIMESTAMP_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"timestamp\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/isoWeek/isoWeek.ts\n// @__NO_SIDE_EFFECTS__\nfunction isoWeek(message2) {\n return {\n kind: \"validation\",\n type: \"iso_week\",\n reference: isoWeek,\n async: false,\n expects: null,\n requirement: ISO_WEEK_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"week\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/length/length.ts\n// @__NO_SIDE_EFFECTS__\nfunction length(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"length\",\n reference: length,\n async: false,\n expects: `${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.length !== this.requirement) {\n _addIssue(this, \"length\", dataset, config2, {\n received: `${dataset.value.length}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/ltValue/ltValue.ts\n// @__NO_SIDE_EFFECTS__\nfunction ltValue(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"lt_value\",\n reference: ltValue,\n async: false,\n expects: `<${requirement instanceof Date ? requirement.toJSON() : _stringify(requirement)}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !(dataset.value < this.requirement)) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/mac/mac.ts\n// @__NO_SIDE_EFFECTS__\nfunction mac(message2) {\n return {\n kind: \"validation\",\n type: \"mac\",\n reference: mac,\n async: false,\n expects: null,\n requirement: MAC_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"MAC\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/mac48/mac48.ts\n// @__NO_SIDE_EFFECTS__\nfunction mac48(message2) {\n return {\n kind: \"validation\",\n type: \"mac48\",\n reference: mac48,\n async: false,\n expects: null,\n requirement: MAC48_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"48-bit MAC\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/mac64/mac64.ts\n// @__NO_SIDE_EFFECTS__\nfunction mac64(message2) {\n return {\n kind: \"validation\",\n type: \"mac64\",\n reference: mac64,\n async: false,\n expects: null,\n requirement: MAC64_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"64-bit MAC\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/mapItems/mapItems.ts\n// @__NO_SIDE_EFFECTS__\nfunction mapItems(operation) {\n return {\n kind: \"transformation\",\n type: \"map_items\",\n reference: mapItems,\n async: false,\n operation,\n \"~run\"(dataset) {\n dataset.value = dataset.value.map(this.operation);\n return dataset;\n }\n };\n}\n\n// src/actions/maxBytes/maxBytes.ts\n// @__NO_SIDE_EFFECTS__\nfunction maxBytes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"max_bytes\",\n reference: maxBytes,\n async: false,\n expects: `<=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const length2 = _getByteCount(dataset.value);\n if (length2 > this.requirement) {\n _addIssue(this, \"bytes\", dataset, config2, {\n received: `${length2}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/maxEntries/maxEntries.ts\n// @__NO_SIDE_EFFECTS__\nfunction maxEntries(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"max_entries\",\n reference: maxEntries,\n async: false,\n expects: `<=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (!dataset.typed) return dataset;\n const count = Object.keys(dataset.value).length;\n if (dataset.typed && count > this.requirement) {\n _addIssue(this, \"entries\", dataset, config2, {\n received: `${count}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/maxGraphemes/maxGraphemes.ts\n// @__NO_SIDE_EFFECTS__\nfunction maxGraphemes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"max_graphemes\",\n reference: maxGraphemes,\n async: false,\n expects: `<=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getGraphemeCount(dataset.value);\n if (count > this.requirement) {\n _addIssue(this, \"graphemes\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/maxLength/maxLength.ts\n// @__NO_SIDE_EFFECTS__\nfunction maxLength(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"max_length\",\n reference: maxLength,\n async: false,\n expects: `<=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.length > this.requirement) {\n _addIssue(this, \"length\", dataset, config2, {\n received: `${dataset.value.length}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/maxSize/maxSize.ts\n// @__NO_SIDE_EFFECTS__\nfunction maxSize(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"max_size\",\n reference: maxSize,\n async: false,\n expects: `<=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.size > this.requirement) {\n _addIssue(this, \"size\", dataset, config2, {\n received: `${dataset.value.size}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/maxValue/maxValue.ts\n// @__NO_SIDE_EFFECTS__\nfunction maxValue(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"max_value\",\n reference: maxValue,\n async: false,\n expects: `<=${requirement instanceof Date ? requirement.toJSON() : _stringify(requirement)}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !(dataset.value <= this.requirement)) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/maxWords/maxWords.ts\n// @__NO_SIDE_EFFECTS__\nfunction maxWords(locales, requirement, message2) {\n return {\n kind: \"validation\",\n type: \"max_words\",\n reference: maxWords,\n async: false,\n expects: `<=${requirement}`,\n locales,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getWordCount(this.locales, dataset.value);\n if (count > this.requirement) {\n _addIssue(this, \"words\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/metadata/metadata.ts\n// @__NO_SIDE_EFFECTS__\nfunction metadata(metadata_) {\n return {\n kind: \"metadata\",\n type: \"metadata\",\n reference: metadata,\n metadata: metadata_\n };\n}\n\n// src/actions/mimeType/mimeType.ts\n// @__NO_SIDE_EFFECTS__\nfunction mimeType(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"mime_type\",\n reference: mimeType,\n async: false,\n expects: _joinExpects(\n requirement.map((option) => `\"${option}\"`),\n \"|\"\n ),\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.includes(dataset.value.type)) {\n _addIssue(this, \"MIME type\", dataset, config2, {\n received: `\"${dataset.value.type}\"`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/minBytes/minBytes.ts\n// @__NO_SIDE_EFFECTS__\nfunction minBytes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"min_bytes\",\n reference: minBytes,\n async: false,\n expects: `>=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const length2 = _getByteCount(dataset.value);\n if (length2 < this.requirement) {\n _addIssue(this, \"bytes\", dataset, config2, {\n received: `${length2}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/minEntries/minEntries.ts\n// @__NO_SIDE_EFFECTS__\nfunction minEntries(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"min_entries\",\n reference: minEntries,\n async: false,\n expects: `>=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (!dataset.typed) return dataset;\n const count = Object.keys(dataset.value).length;\n if (dataset.typed && count < this.requirement) {\n _addIssue(this, \"entries\", dataset, config2, {\n received: `${count}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/minGraphemes/minGraphemes.ts\n// @__NO_SIDE_EFFECTS__\nfunction minGraphemes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"min_graphemes\",\n reference: minGraphemes,\n async: false,\n expects: `>=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getGraphemeCount(dataset.value);\n if (count < this.requirement) {\n _addIssue(this, \"graphemes\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/minLength/minLength.ts\n// @__NO_SIDE_EFFECTS__\nfunction minLength(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"min_length\",\n reference: minLength,\n async: false,\n expects: `>=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.length < this.requirement) {\n _addIssue(this, \"length\", dataset, config2, {\n received: `${dataset.value.length}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/minSize/minSize.ts\n// @__NO_SIDE_EFFECTS__\nfunction minSize(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"min_size\",\n reference: minSize,\n async: false,\n expects: `>=${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.size < this.requirement) {\n _addIssue(this, \"size\", dataset, config2, {\n received: `${dataset.value.size}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/minValue/minValue.ts\n// @__NO_SIDE_EFFECTS__\nfunction minValue(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"min_value\",\n reference: minValue,\n async: false,\n expects: `>=${requirement instanceof Date ? requirement.toJSON() : _stringify(requirement)}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !(dataset.value >= this.requirement)) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/minWords/minWords.ts\n// @__NO_SIDE_EFFECTS__\nfunction minWords(locales, requirement, message2) {\n return {\n kind: \"validation\",\n type: \"min_words\",\n reference: minWords,\n async: false,\n expects: `>=${requirement}`,\n locales,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getWordCount(this.locales, dataset.value);\n if (count < this.requirement) {\n _addIssue(this, \"words\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/multipleOf/multipleOf.ts\n// @__NO_SIDE_EFFECTS__\nfunction multipleOf(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"multiple_of\",\n reference: multipleOf,\n async: false,\n expects: `%${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value % this.requirement != 0) {\n _addIssue(this, \"multiple\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/nanoid/nanoid.ts\n// @__NO_SIDE_EFFECTS__\nfunction nanoid(message2) {\n return {\n kind: \"validation\",\n type: \"nanoid\",\n reference: nanoid,\n async: false,\n expects: null,\n requirement: NANO_ID_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"Nano ID\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/nonEmpty/nonEmpty.ts\n// @__NO_SIDE_EFFECTS__\nfunction nonEmpty(message2) {\n return {\n kind: \"validation\",\n type: \"non_empty\",\n reference: nonEmpty,\n async: false,\n expects: \"!0\",\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.length === 0) {\n _addIssue(this, \"length\", dataset, config2, {\n received: \"0\"\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/normalize/normalize.ts\n// @__NO_SIDE_EFFECTS__\nfunction normalize(form) {\n return {\n kind: \"transformation\",\n type: \"normalize\",\n reference: normalize,\n async: false,\n form,\n \"~run\"(dataset) {\n dataset.value = dataset.value.normalize(this.form);\n return dataset;\n }\n };\n}\n\n// src/actions/notBytes/notBytes.ts\n// @__NO_SIDE_EFFECTS__\nfunction notBytes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_bytes\",\n reference: notBytes,\n async: false,\n expects: `!${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const length2 = _getByteCount(dataset.value);\n if (length2 === this.requirement) {\n _addIssue(this, \"bytes\", dataset, config2, {\n received: `${length2}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/notEntries/notEntries.ts\n// @__NO_SIDE_EFFECTS__\nfunction notEntries(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_entries\",\n reference: notEntries,\n async: false,\n expects: `!${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (!dataset.typed) return dataset;\n const count = Object.keys(dataset.value).length;\n if (dataset.typed && count === this.requirement) {\n _addIssue(this, \"entries\", dataset, config2, {\n received: `${count}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/notGraphemes/notGraphemes.ts\n// @__NO_SIDE_EFFECTS__\nfunction notGraphemes(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_graphemes\",\n reference: notGraphemes,\n async: false,\n expects: `!${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getGraphemeCount(dataset.value);\n if (count === this.requirement) {\n _addIssue(this, \"graphemes\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/notLength/notLength.ts\n// @__NO_SIDE_EFFECTS__\nfunction notLength(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_length\",\n reference: notLength,\n async: false,\n expects: `!${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.length === this.requirement) {\n _addIssue(this, \"length\", dataset, config2, {\n received: `${dataset.value.length}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/notSize/notSize.ts\n// @__NO_SIDE_EFFECTS__\nfunction notSize(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_size\",\n reference: notSize,\n async: false,\n expects: `!${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.size === this.requirement) {\n _addIssue(this, \"size\", dataset, config2, {\n received: `${dataset.value.size}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/notValue/notValue.ts\n// @__NO_SIDE_EFFECTS__\nfunction notValue(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_value\",\n reference: notValue,\n async: false,\n expects: requirement instanceof Date ? `!${requirement.toJSON()}` : `!${_stringify(requirement)}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && this.requirement <= dataset.value && this.requirement >= dataset.value) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/notValues/notValues.ts\n// @__NO_SIDE_EFFECTS__\nfunction notValues(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_values\",\n reference: notValues,\n async: false,\n expects: `!${_joinExpects(\n requirement.map(\n (value2) => value2 instanceof Date ? value2.toJSON() : _stringify(value2)\n ),\n \"|\"\n )}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && this.requirement.some(\n (value2) => value2 <= dataset.value && value2 >= dataset.value\n )) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/notWords/notWords.ts\n// @__NO_SIDE_EFFECTS__\nfunction notWords(locales, requirement, message2) {\n return {\n kind: \"validation\",\n type: \"not_words\",\n reference: notWords,\n async: false,\n expects: `!${requirement}`,\n locales,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getWordCount(this.locales, dataset.value);\n if (count === this.requirement) {\n _addIssue(this, \"words\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/octal/octal.ts\n// @__NO_SIDE_EFFECTS__\nfunction octal(message2) {\n return {\n kind: \"validation\",\n type: \"octal\",\n reference: octal,\n async: false,\n expects: null,\n requirement: OCTAL_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"octal\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/parseJson/parseJson.ts\n// @__NO_SIDE_EFFECTS__\nfunction parseJson(config2, message2) {\n return {\n kind: \"transformation\",\n type: \"parse_json\",\n reference: parseJson,\n config: config2,\n message: message2,\n async: false,\n \"~run\"(dataset, config3) {\n try {\n dataset.value = JSON.parse(dataset.value, this.config?.reviver);\n } catch (error) {\n if (error instanceof Error) {\n _addIssue(this, \"JSON\", dataset, config3, {\n received: `\"${error.message}\"`\n });\n dataset.typed = false;\n } else {\n throw error;\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/partialCheck/utils/_isPartiallyTyped/_isPartiallyTyped.ts\n// @__NO_SIDE_EFFECTS__\nfunction _isPartiallyTyped(dataset, paths) {\n if (dataset.issues) {\n for (const path of paths) {\n for (const issue of dataset.issues) {\n let typed = false;\n const bound = Math.min(path.length, issue.path?.length ?? 0);\n for (let index = 0; index < bound; index++) {\n if (\n // @ts-expect-error\n path[index] !== issue.path[index].key && // @ts-expect-error\n (path[index] !== \"$\" || issue.path[index].type !== \"array\")\n ) {\n typed = true;\n break;\n }\n }\n if (!typed) {\n return false;\n }\n }\n }\n }\n return true;\n}\n\n// src/actions/partialCheck/partialCheck.ts\n// @__NO_SIDE_EFFECTS__\nfunction partialCheck(paths, requirement, message2) {\n return {\n kind: \"validation\",\n type: \"partial_check\",\n reference: partialCheck,\n async: false,\n expects: null,\n paths,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if ((dataset.typed || _isPartiallyTyped(dataset, paths)) && // @ts-expect-error\n !this.requirement(dataset.value)) {\n _addIssue(this, \"input\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/partialCheck/partialCheckAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction partialCheckAsync(paths, requirement, message2) {\n return {\n kind: \"validation\",\n type: \"partial_check\",\n reference: partialCheckAsync,\n async: true,\n expects: null,\n paths,\n requirement,\n message: message2,\n async \"~run\"(dataset, config2) {\n if ((dataset.typed || _isPartiallyTyped(dataset, paths)) && // @ts-expect-error\n !await this.requirement(dataset.value)) {\n _addIssue(this, \"input\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/rawCheck/rawCheck.ts\n// @__NO_SIDE_EFFECTS__\nfunction rawCheck(action) {\n return {\n kind: \"validation\",\n type: \"raw_check\",\n reference: rawCheck,\n async: false,\n expects: null,\n \"~run\"(dataset, config2) {\n action({\n dataset,\n config: config2,\n addIssue: (info) => _addIssue(this, info?.label ?? \"input\", dataset, config2, info)\n });\n return dataset;\n }\n };\n}\n\n// src/actions/rawCheck/rawCheckAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction rawCheckAsync(action) {\n return {\n kind: \"validation\",\n type: \"raw_check\",\n reference: rawCheckAsync,\n async: true,\n expects: null,\n async \"~run\"(dataset, config2) {\n await action({\n dataset,\n config: config2,\n addIssue: (info) => _addIssue(this, info?.label ?? \"input\", dataset, config2, info)\n });\n return dataset;\n }\n };\n}\n\n// src/actions/rawTransform/rawTransform.ts\n// @__NO_SIDE_EFFECTS__\nfunction rawTransform(action) {\n return {\n kind: \"transformation\",\n type: \"raw_transform\",\n reference: rawTransform,\n async: false,\n \"~run\"(dataset, config2) {\n const output = action({\n dataset,\n config: config2,\n addIssue: (info) => _addIssue(this, info?.label ?? \"input\", dataset, config2, info),\n NEVER: null\n });\n if (dataset.issues) {\n dataset.typed = false;\n } else {\n dataset.value = output;\n }\n return dataset;\n }\n };\n}\n\n// src/actions/rawTransform/rawTransformAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction rawTransformAsync(action) {\n return {\n kind: \"transformation\",\n type: \"raw_transform\",\n reference: rawTransformAsync,\n async: true,\n async \"~run\"(dataset, config2) {\n const output = await action({\n dataset,\n config: config2,\n addIssue: (info) => _addIssue(this, info?.label ?? \"input\", dataset, config2, info),\n NEVER: null\n });\n if (dataset.issues) {\n dataset.typed = false;\n } else {\n dataset.value = output;\n }\n return dataset;\n }\n };\n}\n\n// src/actions/readonly/readonly.ts\n// @__NO_SIDE_EFFECTS__\nfunction readonly() {\n return {\n kind: \"transformation\",\n type: \"readonly\",\n reference: readonly,\n async: false,\n \"~run\"(dataset) {\n return dataset;\n }\n };\n}\n\n// src/actions/reduceItems/reduceItems.ts\n// @__NO_SIDE_EFFECTS__\nfunction reduceItems(operation, initial) {\n return {\n kind: \"transformation\",\n type: \"reduce_items\",\n reference: reduceItems,\n async: false,\n operation,\n initial,\n \"~run\"(dataset) {\n dataset.value = dataset.value.reduce(this.operation, this.initial);\n return dataset;\n }\n };\n}\n\n// src/actions/regex/regex.ts\n// @__NO_SIDE_EFFECTS__\nfunction regex(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"regex\",\n reference: regex,\n async: false,\n expects: `${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"format\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/returns/returns.ts\n// @__NO_SIDE_EFFECTS__\nfunction returns(schema) {\n return {\n kind: \"transformation\",\n type: \"returns\",\n reference: returns,\n async: false,\n schema,\n \"~run\"(dataset, config2) {\n const func = dataset.value;\n dataset.value = (...args_) => {\n const returnsDataset = this.schema[\"~run\"](\n { value: func(...args_) },\n config2\n );\n if (returnsDataset.issues) {\n throw new ValiError(returnsDataset.issues);\n }\n return returnsDataset.value;\n };\n return dataset;\n }\n };\n}\n\n// src/actions/returns/returnsAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction returnsAsync(schema) {\n return {\n kind: \"transformation\",\n type: \"returns\",\n reference: returnsAsync,\n async: false,\n schema,\n \"~run\"(dataset, config2) {\n const func = dataset.value;\n dataset.value = async (...args_) => {\n const returnsDataset = await this.schema[\"~run\"](\n { value: await func(...args_) },\n config2\n );\n if (returnsDataset.issues) {\n throw new ValiError(returnsDataset.issues);\n }\n return returnsDataset.value;\n };\n return dataset;\n }\n };\n}\n\n// src/actions/rfcEmail/rfcEmail.ts\n// @__NO_SIDE_EFFECTS__\nfunction rfcEmail(message2) {\n return {\n kind: \"validation\",\n type: \"rfc_email\",\n reference: rfcEmail,\n expects: null,\n async: false,\n requirement: RFC_EMAIL_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"email\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/safeInteger/safeInteger.ts\n// @__NO_SIDE_EFFECTS__\nfunction safeInteger(message2) {\n return {\n kind: \"validation\",\n type: \"safe_integer\",\n reference: safeInteger,\n async: false,\n expects: null,\n requirement: Number.isSafeInteger,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement(dataset.value)) {\n _addIssue(this, \"safe integer\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/size/size.ts\n// @__NO_SIDE_EFFECTS__\nfunction size(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"size\",\n reference: size,\n async: false,\n expects: `${requirement}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && dataset.value.size !== this.requirement) {\n _addIssue(this, \"size\", dataset, config2, {\n received: `${dataset.value.size}`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/slug/slug.ts\n// @__NO_SIDE_EFFECTS__\nfunction slug(message2) {\n return {\n kind: \"validation\",\n type: \"slug\",\n reference: slug,\n async: false,\n expects: null,\n requirement: SLUG_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"slug\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/someItem/someItem.ts\n// @__NO_SIDE_EFFECTS__\nfunction someItem(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"some_item\",\n reference: someItem,\n async: false,\n expects: null,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !dataset.value.some(this.requirement)) {\n _addIssue(this, \"item\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/sortItems/sortItems.ts\n// @__NO_SIDE_EFFECTS__\nfunction sortItems(operation) {\n return {\n kind: \"transformation\",\n type: \"sort_items\",\n reference: sortItems,\n async: false,\n operation,\n \"~run\"(dataset) {\n dataset.value = dataset.value.sort(this.operation);\n return dataset;\n }\n };\n}\n\n// src/actions/startsWith/startsWith.ts\n// @__NO_SIDE_EFFECTS__\nfunction startsWith(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"starts_with\",\n reference: startsWith,\n async: false,\n expects: `\"${requirement}\"`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !dataset.value.startsWith(this.requirement)) {\n _addIssue(this, \"start\", dataset, config2, {\n received: `\"${dataset.value.slice(0, this.requirement.length)}\"`\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/stringifyJson/stringifyJson.ts\n// @__NO_SIDE_EFFECTS__\nfunction stringifyJson(config2, message2) {\n return {\n kind: \"transformation\",\n type: \"stringify_json\",\n reference: stringifyJson,\n message: message2,\n config: config2,\n async: false,\n \"~run\"(dataset, config3) {\n try {\n const output = JSON.stringify(\n dataset.value,\n // @ts-expect-error\n this.config?.replacer,\n this.config?.space\n );\n if (output === void 0) {\n _addIssue(this, \"JSON\", dataset, config3);\n dataset.typed = false;\n }\n dataset.value = output;\n } catch (error) {\n if (error instanceof Error) {\n _addIssue(this, \"JSON\", dataset, config3, {\n received: `\"${error.message}\"`\n });\n dataset.typed = false;\n } else {\n throw error;\n }\n }\n return dataset;\n }\n };\n}\n\n// src/actions/title/title.ts\n// @__NO_SIDE_EFFECTS__\nfunction title(title_) {\n return {\n kind: \"metadata\",\n type: \"title\",\n reference: title,\n title: title_\n };\n}\n\n// src/actions/toLowerCase/toLowerCase.ts\n// @__NO_SIDE_EFFECTS__\nfunction toLowerCase() {\n return {\n kind: \"transformation\",\n type: \"to_lower_case\",\n reference: toLowerCase,\n async: false,\n \"~run\"(dataset) {\n dataset.value = dataset.value.toLowerCase();\n return dataset;\n }\n };\n}\n\n// src/actions/toMaxValue/toMaxValue.ts\n// @__NO_SIDE_EFFECTS__\nfunction toMaxValue(requirement) {\n return {\n kind: \"transformation\",\n type: \"to_max_value\",\n reference: toMaxValue,\n async: false,\n requirement,\n \"~run\"(dataset) {\n dataset.value = dataset.value > this.requirement ? this.requirement : dataset.value;\n return dataset;\n }\n };\n}\n\n// src/actions/toMinValue/toMinValue.ts\n// @__NO_SIDE_EFFECTS__\nfunction toMinValue(requirement) {\n return {\n kind: \"transformation\",\n type: \"to_min_value\",\n reference: toMinValue,\n async: false,\n requirement,\n \"~run\"(dataset) {\n dataset.value = dataset.value < this.requirement ? this.requirement : dataset.value;\n return dataset;\n }\n };\n}\n\n// src/actions/toUpperCase/toUpperCase.ts\n// @__NO_SIDE_EFFECTS__\nfunction toUpperCase() {\n return {\n kind: \"transformation\",\n type: \"to_upper_case\",\n reference: toUpperCase,\n async: false,\n \"~run\"(dataset) {\n dataset.value = dataset.value.toUpperCase();\n return dataset;\n }\n };\n}\n\n// src/actions/transform/transform.ts\n// @__NO_SIDE_EFFECTS__\nfunction transform(operation) {\n return {\n kind: \"transformation\",\n type: \"transform\",\n reference: transform,\n async: false,\n operation,\n \"~run\"(dataset) {\n dataset.value = this.operation(dataset.value);\n return dataset;\n }\n };\n}\n\n// src/actions/transform/transformAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction transformAsync(operation) {\n return {\n kind: \"transformation\",\n type: \"transform\",\n reference: transformAsync,\n async: true,\n operation,\n async \"~run\"(dataset) {\n dataset.value = await this.operation(dataset.value);\n return dataset;\n }\n };\n}\n\n// src/actions/trim/trim.ts\n// @__NO_SIDE_EFFECTS__\nfunction trim() {\n return {\n kind: \"transformation\",\n type: \"trim\",\n reference: trim,\n async: false,\n \"~run\"(dataset) {\n dataset.value = dataset.value.trim();\n return dataset;\n }\n };\n}\n\n// src/actions/trimEnd/trimEnd.ts\n// @__NO_SIDE_EFFECTS__\nfunction trimEnd() {\n return {\n kind: \"transformation\",\n type: \"trim_end\",\n reference: trimEnd,\n async: false,\n \"~run\"(dataset) {\n dataset.value = dataset.value.trimEnd();\n return dataset;\n }\n };\n}\n\n// src/actions/trimStart/trimStart.ts\n// @__NO_SIDE_EFFECTS__\nfunction trimStart() {\n return {\n kind: \"transformation\",\n type: \"trim_start\",\n reference: trimStart,\n async: false,\n \"~run\"(dataset) {\n dataset.value = dataset.value.trimStart();\n return dataset;\n }\n };\n}\n\n// src/actions/ulid/ulid.ts\n// @__NO_SIDE_EFFECTS__\nfunction ulid(message2) {\n return {\n kind: \"validation\",\n type: \"ulid\",\n reference: ulid,\n async: false,\n expects: null,\n requirement: ULID_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"ULID\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/url/url.ts\n// @__NO_SIDE_EFFECTS__\nfunction url(message2) {\n return {\n kind: \"validation\",\n type: \"url\",\n reference: url,\n async: false,\n expects: null,\n requirement(input) {\n try {\n new URL(input);\n return true;\n } catch {\n return false;\n }\n },\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement(dataset.value)) {\n _addIssue(this, \"URL\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/uuid/uuid.ts\n// @__NO_SIDE_EFFECTS__\nfunction uuid(message2) {\n return {\n kind: \"validation\",\n type: \"uuid\",\n reference: uuid,\n async: false,\n expects: null,\n requirement: UUID_REGEX,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.test(dataset.value)) {\n _addIssue(this, \"UUID\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/actions/value/value.ts\n// @__NO_SIDE_EFFECTS__\nfunction value(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"value\",\n reference: value,\n async: false,\n expects: requirement instanceof Date ? requirement.toJSON() : _stringify(requirement),\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !(this.requirement <= dataset.value && this.requirement >= dataset.value)) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/values/values.ts\n// @__NO_SIDE_EFFECTS__\nfunction values(requirement, message2) {\n return {\n kind: \"validation\",\n type: \"values\",\n reference: values,\n async: false,\n expects: `${_joinExpects(\n requirement.map(\n (value2) => value2 instanceof Date ? value2.toJSON() : _stringify(value2)\n ),\n \"|\"\n )}`,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed && !this.requirement.some(\n (value2) => value2 <= dataset.value && value2 >= dataset.value\n )) {\n _addIssue(this, \"value\", dataset, config2, {\n received: dataset.value instanceof Date ? dataset.value.toJSON() : _stringify(dataset.value)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/actions/words/words.ts\n// @__NO_SIDE_EFFECTS__\nfunction words(locales, requirement, message2) {\n return {\n kind: \"validation\",\n type: \"words\",\n reference: words,\n async: false,\n expects: `${requirement}`,\n locales,\n requirement,\n message: message2,\n \"~run\"(dataset, config2) {\n if (dataset.typed) {\n const count = _getWordCount(this.locales, dataset.value);\n if (count !== this.requirement) {\n _addIssue(this, \"words\", dataset, config2, {\n received: `${count}`\n });\n }\n }\n return dataset;\n }\n };\n}\n\n// src/methods/assert/assert.ts\nfunction assert(schema, input) {\n const issues = schema[\"~run\"]({ value: input }, { abortEarly: true }).issues;\n if (issues) {\n throw new ValiError(issues);\n }\n}\n\n// src/methods/config/config.ts\n// @__NO_SIDE_EFFECTS__\nfunction config(schema, config2) {\n return {\n ...schema,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config_) {\n return schema[\"~run\"](dataset, { ...config_, ...config2 });\n }\n };\n}\n\n// src/methods/getFallback/getFallback.ts\n// @__NO_SIDE_EFFECTS__\nfunction getFallback(schema, dataset, config2) {\n return typeof schema.fallback === \"function\" ? (\n // @ts-expect-error\n schema.fallback(dataset, config2)\n ) : (\n // @ts-expect-error\n schema.fallback\n );\n}\n\n// src/methods/fallback/fallback.ts\n// @__NO_SIDE_EFFECTS__\nfunction fallback(schema, fallback2) {\n return {\n ...schema,\n fallback: fallback2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const outputDataset = schema[\"~run\"](dataset, config2);\n return outputDataset.issues ? { typed: true, value: getFallback(this, outputDataset, config2) } : outputDataset;\n }\n };\n}\n\n// src/methods/fallback/fallbackAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction fallbackAsync(schema, fallback2) {\n return {\n ...schema,\n fallback: fallback2,\n async: true,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const outputDataset = await schema[\"~run\"](dataset, config2);\n return outputDataset.issues ? {\n typed: true,\n value: await getFallback(this, outputDataset, config2)\n } : outputDataset;\n }\n };\n}\n\n// src/methods/flatten/flatten.ts\n// @__NO_SIDE_EFFECTS__\nfunction flatten(issues) {\n const flatErrors = {};\n for (const issue of issues) {\n if (issue.path) {\n const dotPath = getDotPath(issue);\n if (dotPath) {\n if (!flatErrors.nested) {\n flatErrors.nested = {};\n }\n if (flatErrors.nested[dotPath]) {\n flatErrors.nested[dotPath].push(issue.message);\n } else {\n flatErrors.nested[dotPath] = [issue.message];\n }\n } else {\n if (flatErrors.other) {\n flatErrors.other.push(issue.message);\n } else {\n flatErrors.other = [issue.message];\n }\n }\n } else {\n if (flatErrors.root) {\n flatErrors.root.push(issue.message);\n } else {\n flatErrors.root = [issue.message];\n }\n }\n }\n return flatErrors;\n}\n\n// src/methods/forward/forward.ts\n// @__NO_SIDE_EFFECTS__\nfunction forward(action, path) {\n return {\n ...action,\n \"~run\"(dataset, config2) {\n const prevIssues = dataset.issues && [...dataset.issues];\n dataset = action[\"~run\"](dataset, config2);\n if (dataset.issues) {\n for (const issue of dataset.issues) {\n if (!prevIssues?.includes(issue)) {\n let pathInput = dataset.value;\n for (const key of path) {\n const pathValue = pathInput[key];\n const pathItem = {\n type: \"unknown\",\n origin: \"value\",\n input: pathInput,\n key,\n value: pathValue\n };\n if (issue.path) {\n issue.path.push(pathItem);\n } else {\n issue.path = [pathItem];\n }\n if (!pathValue) {\n break;\n }\n pathInput = pathValue;\n }\n }\n }\n }\n return dataset;\n }\n };\n}\n\n// src/methods/forward/forwardAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction forwardAsync(action, path) {\n return {\n ...action,\n async: true,\n async \"~run\"(dataset, config2) {\n const prevIssues = dataset.issues && [...dataset.issues];\n dataset = await action[\"~run\"](dataset, config2);\n if (dataset.issues) {\n for (const issue of dataset.issues) {\n if (!prevIssues?.includes(issue)) {\n let pathInput = dataset.value;\n for (const key of path) {\n const pathValue = pathInput[key];\n const pathItem = {\n type: \"unknown\",\n origin: \"value\",\n input: pathInput,\n key,\n value: pathValue\n };\n if (issue.path) {\n issue.path.push(pathItem);\n } else {\n issue.path = [pathItem];\n }\n if (!pathValue) {\n break;\n }\n pathInput = pathValue;\n }\n }\n }\n }\n return dataset;\n }\n };\n}\n\n// src/methods/getDefault/getDefault.ts\n// @__NO_SIDE_EFFECTS__\nfunction getDefault(schema, dataset, config2) {\n return typeof schema.default === \"function\" ? (\n // @ts-expect-error\n schema.default(dataset, config2)\n ) : (\n // @ts-expect-error\n schema.default\n );\n}\n\n// src/methods/getDefaults/getDefaults.ts\n// @__NO_SIDE_EFFECTS__\nfunction getDefaults(schema) {\n if (\"entries\" in schema) {\n const object2 = {};\n for (const key in schema.entries) {\n object2[key] = /* @__PURE__ */ getDefaults(schema.entries[key]);\n }\n return object2;\n }\n if (\"items\" in schema) {\n return schema.items.map(getDefaults);\n }\n return getDefault(schema);\n}\n\n// src/methods/getDefaults/getDefaultsAsync.ts\n// @__NO_SIDE_EFFECTS__\nasync function getDefaultsAsync(schema) {\n if (\"entries\" in schema) {\n return Object.fromEntries(\n await Promise.all(\n Object.entries(schema.entries).map(async ([key, value2]) => [\n key,\n await /* @__PURE__ */ getDefaultsAsync(value2)\n ])\n )\n );\n }\n if (\"items\" in schema) {\n return Promise.all(schema.items.map(getDefaultsAsync));\n }\n return getDefault(schema);\n}\n\n// src/methods/getDescription/getDescription.ts\n// @__NO_SIDE_EFFECTS__\nfunction getDescription(schema) {\n return _getLastMetadata(schema, \"description\");\n}\n\n// src/methods/getFallbacks/getFallbacks.ts\n// @__NO_SIDE_EFFECTS__\nfunction getFallbacks(schema) {\n if (\"entries\" in schema) {\n const object2 = {};\n for (const key in schema.entries) {\n object2[key] = /* @__PURE__ */ getFallbacks(schema.entries[key]);\n }\n return object2;\n }\n if (\"items\" in schema) {\n return schema.items.map(getFallbacks);\n }\n return getFallback(schema);\n}\n\n// src/methods/getFallbacks/getFallbacksAsync.ts\n// @__NO_SIDE_EFFECTS__\nasync function getFallbacksAsync(schema) {\n if (\"entries\" in schema) {\n return Object.fromEntries(\n await Promise.all(\n Object.entries(schema.entries).map(async ([key, value2]) => [\n key,\n await /* @__PURE__ */ getFallbacksAsync(value2)\n ])\n )\n );\n }\n if (\"items\" in schema) {\n return Promise.all(schema.items.map(getFallbacksAsync));\n }\n return getFallback(schema);\n}\n\n// src/methods/getMetadata/getMetadata.ts\n// @__NO_SIDE_EFFECTS__\nfunction getMetadata(schema) {\n const result = {};\n function depthFirstMerge(schema2) {\n if (\"pipe\" in schema2) {\n for (const item of schema2.pipe) {\n if (item.kind === \"schema\" && \"pipe\" in item) {\n depthFirstMerge(item);\n } else if (item.kind === \"metadata\" && item.type === \"metadata\") {\n Object.assign(result, item.metadata);\n }\n }\n }\n }\n depthFirstMerge(schema);\n return result;\n}\n\n// src/methods/getTitle/getTitle.ts\n// @__NO_SIDE_EFFECTS__\nfunction getTitle(schema) {\n return _getLastMetadata(schema, \"title\");\n}\n\n// src/methods/is/is.ts\n// @__NO_SIDE_EFFECTS__\nfunction is(schema, input) {\n return !schema[\"~run\"]({ value: input }, { abortEarly: true }).issues;\n}\n\n// src/schemas/any/any.ts\n// @__NO_SIDE_EFFECTS__\nfunction any() {\n return {\n kind: \"schema\",\n type: \"any\",\n reference: any,\n expects: \"any\",\n async: false,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset) {\n dataset.typed = true;\n return dataset;\n }\n };\n}\n\n// src/schemas/array/array.ts\n// @__NO_SIDE_EFFECTS__\nfunction array(item, message2) {\n return {\n kind: \"schema\",\n type: \"array\",\n reference: array,\n expects: \"Array\",\n async: false,\n item,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n for (let key = 0; key < input.length; key++) {\n const value2 = input[key];\n const itemDataset = this.item[\"~run\"]({ value: value2 }, config2);\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/array/arrayAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction arrayAsync(item, message2) {\n return {\n kind: \"schema\",\n type: \"array\",\n reference: arrayAsync,\n expects: \"Array\",\n async: true,\n item,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n const itemDatasets = await Promise.all(\n input.map((value2) => this.item[\"~run\"]({ value: value2 }, config2))\n );\n for (let key = 0; key < itemDatasets.length; key++) {\n const itemDataset = itemDatasets[key];\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: input[key]\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/bigint/bigint.ts\n// @__NO_SIDE_EFFECTS__\nfunction bigint(message2) {\n return {\n kind: \"schema\",\n type: \"bigint\",\n reference: bigint,\n expects: \"bigint\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (typeof dataset.value === \"bigint\") {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/blob/blob.ts\n// @__NO_SIDE_EFFECTS__\nfunction blob(message2) {\n return {\n kind: \"schema\",\n type: \"blob\",\n reference: blob,\n expects: \"Blob\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value instanceof Blob) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/boolean/boolean.ts\n// @__NO_SIDE_EFFECTS__\nfunction boolean(message2) {\n return {\n kind: \"schema\",\n type: \"boolean\",\n reference: boolean,\n expects: \"boolean\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (typeof dataset.value === \"boolean\") {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/custom/custom.ts\n// @__NO_SIDE_EFFECTS__\nfunction custom(check2, message2) {\n return {\n kind: \"schema\",\n type: \"custom\",\n reference: custom,\n expects: \"unknown\",\n async: false,\n check: check2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (this.check(dataset.value)) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/custom/customAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction customAsync(check2, message2) {\n return {\n kind: \"schema\",\n type: \"custom\",\n reference: customAsync,\n expects: \"unknown\",\n async: true,\n check: check2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (await this.check(dataset.value)) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/date/date.ts\n// @__NO_SIDE_EFFECTS__\nfunction date(message2) {\n return {\n kind: \"schema\",\n type: \"date\",\n reference: date,\n expects: \"Date\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value instanceof Date) {\n if (!isNaN(dataset.value)) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2, {\n received: '\"Invalid Date\"'\n });\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/enum/enum.ts\n// @__NO_SIDE_EFFECTS__\nfunction enum_(enum__, message2) {\n const options = [];\n for (const key in enum__) {\n if (`${+key}` !== key || typeof enum__[key] !== \"string\" || !Object.is(enum__[enum__[key]], +key)) {\n options.push(enum__[key]);\n }\n }\n return {\n kind: \"schema\",\n type: \"enum\",\n reference: enum_,\n expects: _joinExpects(options.map(_stringify), \"|\"),\n async: false,\n enum: enum__,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (this.options.includes(dataset.value)) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/exactOptional/exactOptional.ts\n// @__NO_SIDE_EFFECTS__\nfunction exactOptional(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"exact_optional\",\n reference: exactOptional,\n expects: wrapped.expects,\n async: false,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/exactOptional/exactOptionalAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction exactOptionalAsync(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"exact_optional\",\n reference: exactOptionalAsync,\n expects: wrapped.expects,\n async: true,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/file/file.ts\n// @__NO_SIDE_EFFECTS__\nfunction file(message2) {\n return {\n kind: \"schema\",\n type: \"file\",\n reference: file,\n expects: \"File\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value instanceof File) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/function/function.ts\n// @__NO_SIDE_EFFECTS__\nfunction function_(message2) {\n return {\n kind: \"schema\",\n type: \"function\",\n reference: function_,\n expects: \"Function\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (typeof dataset.value === \"function\") {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/instance/instance.ts\n// @__NO_SIDE_EFFECTS__\nfunction instance(class_, message2) {\n return {\n kind: \"schema\",\n type: \"instance\",\n reference: instance,\n expects: class_.name,\n async: false,\n class: class_,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value instanceof this.class) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/intersect/utils/_merge/_merge.ts\n// @__NO_SIDE_EFFECTS__\nfunction _merge(value1, value2) {\n if (typeof value1 === typeof value2) {\n if (value1 === value2 || value1 instanceof Date && value2 instanceof Date && +value1 === +value2) {\n return { value: value1 };\n }\n if (value1 && value2 && value1.constructor === Object && value2.constructor === Object) {\n for (const key in value2) {\n if (key in value1) {\n const dataset = /* @__PURE__ */ _merge(value1[key], value2[key]);\n if (dataset.issue) {\n return dataset;\n }\n value1[key] = dataset.value;\n } else {\n value1[key] = value2[key];\n }\n }\n return { value: value1 };\n }\n if (Array.isArray(value1) && Array.isArray(value2)) {\n if (value1.length === value2.length) {\n for (let index = 0; index < value1.length; index++) {\n const dataset = /* @__PURE__ */ _merge(value1[index], value2[index]);\n if (dataset.issue) {\n return dataset;\n }\n value1[index] = dataset.value;\n }\n return { value: value1 };\n }\n }\n }\n return { issue: true };\n}\n\n// src/schemas/intersect/intersect.ts\n// @__NO_SIDE_EFFECTS__\nfunction intersect(options, message2) {\n return {\n kind: \"schema\",\n type: \"intersect\",\n reference: intersect,\n expects: _joinExpects(\n options.map((option) => option.expects),\n \"&\"\n ),\n async: false,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (this.options.length) {\n const input = dataset.value;\n let outputs;\n dataset.typed = true;\n for (const schema of this.options) {\n const optionDataset = schema[\"~run\"]({ value: input }, config2);\n if (optionDataset.issues) {\n if (dataset.issues) {\n dataset.issues.push(...optionDataset.issues);\n } else {\n dataset.issues = optionDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!optionDataset.typed) {\n dataset.typed = false;\n }\n if (dataset.typed) {\n if (outputs) {\n outputs.push(optionDataset.value);\n } else {\n outputs = [optionDataset.value];\n }\n }\n }\n if (dataset.typed) {\n dataset.value = outputs[0];\n for (let index = 1; index < outputs.length; index++) {\n const mergeDataset = _merge(dataset.value, outputs[index]);\n if (mergeDataset.issue) {\n _addIssue(this, \"type\", dataset, config2, {\n received: \"unknown\"\n });\n break;\n }\n dataset.value = mergeDataset.value;\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/intersect/intersectAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction intersectAsync(options, message2) {\n return {\n kind: \"schema\",\n type: \"intersect\",\n reference: intersectAsync,\n expects: _joinExpects(\n options.map((option) => option.expects),\n \"&\"\n ),\n async: true,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (this.options.length) {\n const input = dataset.value;\n let outputs;\n dataset.typed = true;\n const optionDatasets = await Promise.all(\n this.options.map((schema) => schema[\"~run\"]({ value: input }, config2))\n );\n for (const optionDataset of optionDatasets) {\n if (optionDataset.issues) {\n if (dataset.issues) {\n dataset.issues.push(...optionDataset.issues);\n } else {\n dataset.issues = optionDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!optionDataset.typed) {\n dataset.typed = false;\n }\n if (dataset.typed) {\n if (outputs) {\n outputs.push(optionDataset.value);\n } else {\n outputs = [optionDataset.value];\n }\n }\n }\n if (dataset.typed) {\n dataset.value = outputs[0];\n for (let index = 1; index < outputs.length; index++) {\n const mergeDataset = _merge(dataset.value, outputs[index]);\n if (mergeDataset.issue) {\n _addIssue(this, \"type\", dataset, config2, {\n received: \"unknown\"\n });\n break;\n }\n dataset.value = mergeDataset.value;\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/lazy/lazy.ts\n// @__NO_SIDE_EFFECTS__\nfunction lazy(getter) {\n return {\n kind: \"schema\",\n type: \"lazy\",\n reference: lazy,\n expects: \"unknown\",\n async: false,\n getter,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n return this.getter(dataset.value)[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/lazy/lazyAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction lazyAsync(getter) {\n return {\n kind: \"schema\",\n type: \"lazy\",\n reference: lazyAsync,\n expects: \"unknown\",\n async: true,\n getter,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n return (await this.getter(dataset.value))[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/literal/literal.ts\n// @__NO_SIDE_EFFECTS__\nfunction literal(literal_, message2) {\n return {\n kind: \"schema\",\n type: \"literal\",\n reference: literal,\n expects: _stringify(literal_),\n async: false,\n literal: literal_,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === this.literal) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/looseObject/looseObject.ts\n// @__NO_SIDE_EFFECTS__\nfunction looseObject(entries2, message2) {\n return {\n kind: \"schema\",\n type: \"loose_object\",\n reference: looseObject,\n expects: \"Object\",\n async: false,\n entries: entries2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n for (const key in this.entries) {\n const valueSchema = this.entries[key];\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : getDefault(valueSchema);\n const valueDataset = valueSchema[\"~run\"]({ value: value2 }, config2);\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n // @ts-expect-error\n value: input[key]\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (const key in input) {\n if (_isValidObjectKey(input, key) && !(key in this.entries)) {\n dataset.value[key] = input[key];\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/looseObject/looseObjectAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction looseObjectAsync(entries2, message2) {\n return {\n kind: \"schema\",\n type: \"loose_object\",\n reference: looseObjectAsync,\n expects: \"Object\",\n async: true,\n entries: entries2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n const valueDatasets = await Promise.all(\n Object.entries(this.entries).map(async ([key, valueSchema]) => {\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : await getDefault(valueSchema);\n return [\n key,\n value2,\n valueSchema,\n await valueSchema[\"~run\"]({ value: value2 }, config2)\n ];\n }\n return [\n key,\n // @ts-expect-error\n input[key],\n valueSchema,\n null\n ];\n })\n );\n for (const [key, value2, valueSchema, valueDataset] of valueDatasets) {\n if (valueDataset) {\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = await getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n value: value2\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (const key in input) {\n if (_isValidObjectKey(input, key) && !(key in this.entries)) {\n dataset.value[key] = input[key];\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/looseTuple/looseTuple.ts\n// @__NO_SIDE_EFFECTS__\nfunction looseTuple(items, message2) {\n return {\n kind: \"schema\",\n type: \"loose_tuple\",\n reference: looseTuple,\n expects: \"Array\",\n async: false,\n items,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n for (let key = 0; key < this.items.length; key++) {\n const value2 = input[key];\n const itemDataset = this.items[key][\"~run\"]({ value: value2 }, config2);\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (let key = this.items.length; key < input.length; key++) {\n dataset.value.push(input[key]);\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/looseTuple/looseTupleAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction looseTupleAsync(items, message2) {\n return {\n kind: \"schema\",\n type: \"loose_tuple\",\n reference: looseTupleAsync,\n expects: \"Array\",\n async: true,\n items,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n const itemDatasets = await Promise.all(\n this.items.map(async (item, key) => {\n const value2 = input[key];\n return [key, value2, await item[\"~run\"]({ value: value2 }, config2)];\n })\n );\n for (const [key, value2, itemDataset] of itemDatasets) {\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (let key = this.items.length; key < input.length; key++) {\n dataset.value.push(input[key]);\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/map/map.ts\n// @__NO_SIDE_EFFECTS__\nfunction map(key, value2, message2) {\n return {\n kind: \"schema\",\n type: \"map\",\n reference: map,\n expects: \"Map\",\n async: false,\n key,\n value: value2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input instanceof Map) {\n dataset.typed = true;\n dataset.value = /* @__PURE__ */ new Map();\n for (const [inputKey, inputValue] of input) {\n const keyDataset = this.key[\"~run\"]({ value: inputKey }, config2);\n if (keyDataset.issues) {\n const pathItem = {\n type: \"map\",\n origin: \"key\",\n input,\n key: inputKey,\n value: inputValue\n };\n for (const issue of keyDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = keyDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n const valueDataset = this.value[\"~run\"](\n { value: inputValue },\n config2\n );\n if (valueDataset.issues) {\n const pathItem = {\n type: \"map\",\n origin: \"value\",\n input,\n key: inputKey,\n value: inputValue\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!keyDataset.typed || !valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.set(keyDataset.value, valueDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/map/mapAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction mapAsync(key, value2, message2) {\n return {\n kind: \"schema\",\n type: \"map\",\n reference: mapAsync,\n expects: \"Map\",\n async: true,\n key,\n value: value2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input instanceof Map) {\n dataset.typed = true;\n dataset.value = /* @__PURE__ */ new Map();\n const datasets = await Promise.all(\n [...input].map(\n ([inputKey, inputValue]) => Promise.all([\n inputKey,\n inputValue,\n this.key[\"~run\"]({ value: inputKey }, config2),\n this.value[\"~run\"]({ value: inputValue }, config2)\n ])\n )\n );\n for (const [\n inputKey,\n inputValue,\n keyDataset,\n valueDataset\n ] of datasets) {\n if (keyDataset.issues) {\n const pathItem = {\n type: \"map\",\n origin: \"key\",\n input,\n key: inputKey,\n value: inputValue\n };\n for (const issue of keyDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = keyDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (valueDataset.issues) {\n const pathItem = {\n type: \"map\",\n origin: \"value\",\n input,\n key: inputKey,\n value: inputValue\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!keyDataset.typed || !valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.set(keyDataset.value, valueDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/nan/nan.ts\n// @__NO_SIDE_EFFECTS__\nfunction nan(message2) {\n return {\n kind: \"schema\",\n type: \"nan\",\n reference: nan,\n expects: \"NaN\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (Number.isNaN(dataset.value)) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/never/never.ts\n// @__NO_SIDE_EFFECTS__\nfunction never(message2) {\n return {\n kind: \"schema\",\n type: \"never\",\n reference: never,\n expects: \"never\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n _addIssue(this, \"type\", dataset, config2);\n return dataset;\n }\n };\n}\n\n// src/schemas/nonNullable/nonNullable.ts\n// @__NO_SIDE_EFFECTS__\nfunction nonNullable(wrapped, message2) {\n return {\n kind: \"schema\",\n type: \"non_nullable\",\n reference: nonNullable,\n expects: \"!null\",\n async: false,\n wrapped,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value !== null) {\n dataset = this.wrapped[\"~run\"](dataset, config2);\n }\n if (dataset.value === null) {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/nonNullable/nonNullableAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction nonNullableAsync(wrapped, message2) {\n return {\n kind: \"schema\",\n type: \"non_nullable\",\n reference: nonNullableAsync,\n expects: \"!null\",\n async: true,\n wrapped,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (dataset.value !== null) {\n dataset = await this.wrapped[\"~run\"](dataset, config2);\n }\n if (dataset.value === null) {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/nonNullish/nonNullish.ts\n// @__NO_SIDE_EFFECTS__\nfunction nonNullish(wrapped, message2) {\n return {\n kind: \"schema\",\n type: \"non_nullish\",\n reference: nonNullish,\n expects: \"(!null & !undefined)\",\n async: false,\n wrapped,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (!(dataset.value === null || dataset.value === void 0)) {\n dataset = this.wrapped[\"~run\"](dataset, config2);\n }\n if (dataset.value === null || dataset.value === void 0) {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/nonNullish/nonNullishAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction nonNullishAsync(wrapped, message2) {\n return {\n kind: \"schema\",\n type: \"non_nullish\",\n reference: nonNullishAsync,\n expects: \"(!null & !undefined)\",\n async: true,\n wrapped,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (!(dataset.value === null || dataset.value === void 0)) {\n dataset = await this.wrapped[\"~run\"](dataset, config2);\n }\n if (dataset.value === null || dataset.value === void 0) {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/nonOptional/nonOptional.ts\n// @__NO_SIDE_EFFECTS__\nfunction nonOptional(wrapped, message2) {\n return {\n kind: \"schema\",\n type: \"non_optional\",\n reference: nonOptional,\n expects: \"!undefined\",\n async: false,\n wrapped,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value !== void 0) {\n dataset = this.wrapped[\"~run\"](dataset, config2);\n }\n if (dataset.value === void 0) {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/nonOptional/nonOptionalAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction nonOptionalAsync(wrapped, message2) {\n return {\n kind: \"schema\",\n type: \"non_optional\",\n reference: nonOptionalAsync,\n expects: \"!undefined\",\n async: true,\n wrapped,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (dataset.value !== void 0) {\n dataset = await this.wrapped[\"~run\"](dataset, config2);\n }\n if (dataset.value === void 0) {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/null/null.ts\n// @__NO_SIDE_EFFECTS__\nfunction null_(message2) {\n return {\n kind: \"schema\",\n type: \"null\",\n reference: null_,\n expects: \"null\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === null) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/nullable/nullable.ts\n// @__NO_SIDE_EFFECTS__\nfunction nullable(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"nullable\",\n reference: nullable,\n expects: `(${wrapped.expects} | null)`,\n async: false,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === null) {\n if (this.default !== void 0) {\n dataset.value = getDefault(this, dataset, config2);\n }\n if (dataset.value === null) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/nullable/nullableAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction nullableAsync(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"nullable\",\n reference: nullableAsync,\n expects: `(${wrapped.expects} | null)`,\n async: true,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (dataset.value === null) {\n if (this.default !== void 0) {\n dataset.value = await getDefault(this, dataset, config2);\n }\n if (dataset.value === null) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/nullish/nullish.ts\n// @__NO_SIDE_EFFECTS__\nfunction nullish(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"nullish\",\n reference: nullish,\n expects: `(${wrapped.expects} | null | undefined)`,\n async: false,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === null || dataset.value === void 0) {\n if (this.default !== void 0) {\n dataset.value = getDefault(this, dataset, config2);\n }\n if (dataset.value === null || dataset.value === void 0) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/nullish/nullishAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction nullishAsync(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"nullish\",\n reference: nullishAsync,\n expects: `(${wrapped.expects} | null | undefined)`,\n async: true,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (dataset.value === null || dataset.value === void 0) {\n if (this.default !== void 0) {\n dataset.value = await getDefault(this, dataset, config2);\n }\n if (dataset.value === null || dataset.value === void 0) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/number/number.ts\n// @__NO_SIDE_EFFECTS__\nfunction number(message2) {\n return {\n kind: \"schema\",\n type: \"number\",\n reference: number,\n expects: \"number\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (typeof dataset.value === \"number\" && !isNaN(dataset.value)) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/object/object.ts\n// @__NO_SIDE_EFFECTS__\nfunction object(entries2, message2) {\n return {\n kind: \"schema\",\n type: \"object\",\n reference: object,\n expects: \"Object\",\n async: false,\n entries: entries2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n for (const key in this.entries) {\n const valueSchema = this.entries[key];\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : getDefault(valueSchema);\n const valueDataset = valueSchema[\"~run\"]({ value: value2 }, config2);\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n // @ts-expect-error\n value: input[key]\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/object/objectAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction objectAsync(entries2, message2) {\n return {\n kind: \"schema\",\n type: \"object\",\n reference: objectAsync,\n expects: \"Object\",\n async: true,\n entries: entries2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n const valueDatasets = await Promise.all(\n Object.entries(this.entries).map(async ([key, valueSchema]) => {\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : await getDefault(valueSchema);\n return [\n key,\n value2,\n valueSchema,\n await valueSchema[\"~run\"]({ value: value2 }, config2)\n ];\n }\n return [\n key,\n // @ts-expect-error\n input[key],\n valueSchema,\n null\n ];\n })\n );\n for (const [key, value2, valueSchema, valueDataset] of valueDatasets) {\n if (valueDataset) {\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = await getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n value: value2\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/objectWithRest/objectWithRest.ts\n// @__NO_SIDE_EFFECTS__\nfunction objectWithRest(entries2, rest, message2) {\n return {\n kind: \"schema\",\n type: \"object_with_rest\",\n reference: objectWithRest,\n expects: \"Object\",\n async: false,\n entries: entries2,\n rest,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n for (const key in this.entries) {\n const valueSchema = this.entries[key];\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : getDefault(valueSchema);\n const valueDataset = valueSchema[\"~run\"]({ value: value2 }, config2);\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n // @ts-expect-error\n value: input[key]\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (const key in input) {\n if (_isValidObjectKey(input, key) && !(key in this.entries)) {\n const valueDataset = this.rest[\"~run\"](\n // @ts-expect-error\n { value: input[key] },\n config2\n );\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n // @ts-expect-error\n value: input[key]\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/objectWithRest/objectWithRestAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction objectWithRestAsync(entries2, rest, message2) {\n return {\n kind: \"schema\",\n type: \"object_with_rest\",\n reference: objectWithRestAsync,\n expects: \"Object\",\n async: true,\n entries: entries2,\n rest,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n const [normalDatasets, restDatasets] = await Promise.all([\n // If key is present or its an optional schema with a default value,\n // parse input of key or default value asynchronously\n Promise.all(\n Object.entries(this.entries).map(async ([key, valueSchema]) => {\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : await getDefault(valueSchema);\n return [\n key,\n value2,\n valueSchema,\n await valueSchema[\"~run\"]({ value: value2 }, config2)\n ];\n }\n return [\n key,\n // @ts-expect-error\n input[key],\n valueSchema,\n null\n ];\n })\n ),\n // Parse other entries with rest schema asynchronously\n // Hint: We exclude specific keys for security reasons\n Promise.all(\n Object.entries(input).filter(\n ([key]) => _isValidObjectKey(input, key) && !(key in this.entries)\n ).map(\n async ([key, value2]) => [\n key,\n value2,\n await this.rest[\"~run\"]({ value: value2 }, config2)\n ]\n )\n )\n ]);\n for (const [key, value2, valueSchema, valueDataset] of normalDatasets) {\n if (valueDataset) {\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = await getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n value: value2\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (const [key, value2, valueDataset] of restDatasets) {\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/optional/optional.ts\n// @__NO_SIDE_EFFECTS__\nfunction optional(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"optional\",\n reference: optional,\n expects: `(${wrapped.expects} | undefined)`,\n async: false,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === void 0) {\n if (this.default !== void 0) {\n dataset.value = getDefault(this, dataset, config2);\n }\n if (dataset.value === void 0) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/optional/optionalAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction optionalAsync(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"optional\",\n reference: optionalAsync,\n expects: `(${wrapped.expects} | undefined)`,\n async: true,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (dataset.value === void 0) {\n if (this.default !== void 0) {\n dataset.value = await getDefault(this, dataset, config2);\n }\n if (dataset.value === void 0) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/picklist/picklist.ts\n// @__NO_SIDE_EFFECTS__\nfunction picklist(options, message2) {\n return {\n kind: \"schema\",\n type: \"picklist\",\n reference: picklist,\n expects: _joinExpects(options.map(_stringify), \"|\"),\n async: false,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (this.options.includes(dataset.value)) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/promise/promise.ts\n// @__NO_SIDE_EFFECTS__\nfunction promise(message2) {\n return {\n kind: \"schema\",\n type: \"promise\",\n reference: promise,\n expects: \"Promise\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value instanceof Promise) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/record/record.ts\n// @__NO_SIDE_EFFECTS__\nfunction record(key, value2, message2) {\n return {\n kind: \"schema\",\n type: \"record\",\n reference: record,\n expects: \"Object\",\n async: false,\n key,\n value: value2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n for (const entryKey in input) {\n if (_isValidObjectKey(input, entryKey)) {\n const entryValue = input[entryKey];\n const keyDataset = this.key[\"~run\"]({ value: entryKey }, config2);\n if (keyDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"key\",\n input,\n key: entryKey,\n value: entryValue\n };\n for (const issue of keyDataset.issues) {\n issue.path = [pathItem];\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = keyDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n const valueDataset = this.value[\"~run\"](\n { value: entryValue },\n config2\n );\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key: entryKey,\n value: entryValue\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!keyDataset.typed || !valueDataset.typed) {\n dataset.typed = false;\n }\n if (keyDataset.typed) {\n dataset.value[keyDataset.value] = valueDataset.value;\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/record/recordAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction recordAsync(key, value2, message2) {\n return {\n kind: \"schema\",\n type: \"record\",\n reference: recordAsync,\n expects: \"Object\",\n async: true,\n key,\n value: value2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n const datasets = await Promise.all(\n Object.entries(input).filter(([key2]) => _isValidObjectKey(input, key2)).map(\n ([entryKey, entryValue]) => Promise.all([\n entryKey,\n entryValue,\n this.key[\"~run\"]({ value: entryKey }, config2),\n this.value[\"~run\"]({ value: entryValue }, config2)\n ])\n )\n );\n for (const [\n entryKey,\n entryValue,\n keyDataset,\n valueDataset\n ] of datasets) {\n if (keyDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"key\",\n input,\n key: entryKey,\n value: entryValue\n };\n for (const issue of keyDataset.issues) {\n issue.path = [pathItem];\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = keyDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key: entryKey,\n value: entryValue\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!keyDataset.typed || !valueDataset.typed) {\n dataset.typed = false;\n }\n if (keyDataset.typed) {\n dataset.value[keyDataset.value] = valueDataset.value;\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/set/set.ts\n// @__NO_SIDE_EFFECTS__\nfunction set(value2, message2) {\n return {\n kind: \"schema\",\n type: \"set\",\n reference: set,\n expects: \"Set\",\n async: false,\n value: value2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input instanceof Set) {\n dataset.typed = true;\n dataset.value = /* @__PURE__ */ new Set();\n for (const inputValue of input) {\n const valueDataset = this.value[\"~run\"](\n { value: inputValue },\n config2\n );\n if (valueDataset.issues) {\n const pathItem = {\n type: \"set\",\n origin: \"value\",\n input,\n key: null,\n value: inputValue\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.add(valueDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/set/setAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction setAsync(value2, message2) {\n return {\n kind: \"schema\",\n type: \"set\",\n reference: setAsync,\n expects: \"Set\",\n async: true,\n value: value2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input instanceof Set) {\n dataset.typed = true;\n dataset.value = /* @__PURE__ */ new Set();\n const valueDatasets = await Promise.all(\n [...input].map(\n async (inputValue) => [\n inputValue,\n await this.value[\"~run\"]({ value: inputValue }, config2)\n ]\n )\n );\n for (const [inputValue, valueDataset] of valueDatasets) {\n if (valueDataset.issues) {\n const pathItem = {\n type: \"set\",\n origin: \"value\",\n input,\n key: null,\n value: inputValue\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.add(valueDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/strictObject/strictObject.ts\n// @__NO_SIDE_EFFECTS__\nfunction strictObject(entries2, message2) {\n return {\n kind: \"schema\",\n type: \"strict_object\",\n reference: strictObject,\n expects: \"Object\",\n async: false,\n entries: entries2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n for (const key in this.entries) {\n const valueSchema = this.entries[key];\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : getDefault(valueSchema);\n const valueDataset = valueSchema[\"~run\"]({ value: value2 }, config2);\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n // @ts-expect-error\n value: input[key]\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (const key in input) {\n if (!(key in this.entries)) {\n _addIssue(this, \"key\", dataset, config2, {\n input: key,\n expected: \"never\",\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n // @ts-expect-error\n value: input[key]\n }\n ]\n });\n break;\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/strictObject/strictObjectAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction strictObjectAsync(entries2, message2) {\n return {\n kind: \"schema\",\n type: \"strict_object\",\n reference: strictObjectAsync,\n expects: \"Object\",\n async: true,\n entries: entries2,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n dataset.typed = true;\n dataset.value = {};\n const valueDatasets = await Promise.all(\n Object.entries(this.entries).map(async ([key, valueSchema]) => {\n if (key in input || (valueSchema.type === \"exact_optional\" || valueSchema.type === \"optional\" || valueSchema.type === \"nullish\") && // @ts-expect-error\n valueSchema.default !== void 0) {\n const value2 = key in input ? (\n // @ts-expect-error\n input[key]\n ) : await getDefault(valueSchema);\n return [\n key,\n value2,\n valueSchema,\n await valueSchema[\"~run\"]({ value: value2 }, config2)\n ];\n }\n return [\n key,\n // @ts-expect-error\n input[key],\n valueSchema,\n null\n ];\n })\n );\n for (const [key, value2, valueSchema, valueDataset] of valueDatasets) {\n if (valueDataset) {\n if (valueDataset.issues) {\n const pathItem = {\n type: \"object\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of valueDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = valueDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!valueDataset.typed) {\n dataset.typed = false;\n }\n dataset.value[key] = valueDataset.value;\n } else if (valueSchema.fallback !== void 0) {\n dataset.value[key] = await getFallback(valueSchema);\n } else if (valueSchema.type !== \"exact_optional\" && valueSchema.type !== \"optional\" && valueSchema.type !== \"nullish\") {\n _addIssue(this, \"key\", dataset, config2, {\n input: void 0,\n expected: `\"${key}\"`,\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n value: value2\n }\n ]\n });\n if (config2.abortEarly) {\n break;\n }\n }\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (const key in input) {\n if (!(key in this.entries)) {\n _addIssue(this, \"key\", dataset, config2, {\n input: key,\n expected: \"never\",\n path: [\n {\n type: \"object\",\n origin: \"key\",\n input,\n key,\n // @ts-expect-error\n value: input[key]\n }\n ]\n });\n break;\n }\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/strictTuple/strictTuple.ts\n// @__NO_SIDE_EFFECTS__\nfunction strictTuple(items, message2) {\n return {\n kind: \"schema\",\n type: \"strict_tuple\",\n reference: strictTuple,\n expects: \"Array\",\n async: false,\n items,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n for (let key = 0; key < this.items.length; key++) {\n const value2 = input[key];\n const itemDataset = this.items[key][\"~run\"]({ value: value2 }, config2);\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n if (!(dataset.issues && config2.abortEarly) && this.items.length < input.length) {\n _addIssue(this, \"type\", dataset, config2, {\n input: input[this.items.length],\n expected: \"never\",\n path: [\n {\n type: \"array\",\n origin: \"value\",\n input,\n key: this.items.length,\n value: input[this.items.length]\n }\n ]\n });\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/strictTuple/strictTupleAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction strictTupleAsync(items, message2) {\n return {\n kind: \"schema\",\n type: \"strict_tuple\",\n reference: strictTupleAsync,\n expects: \"Array\",\n async: true,\n items,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n const itemDatasets = await Promise.all(\n this.items.map(async (item, key) => {\n const value2 = input[key];\n return [key, value2, await item[\"~run\"]({ value: value2 }, config2)];\n })\n );\n for (const [key, value2, itemDataset] of itemDatasets) {\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n if (!(dataset.issues && config2.abortEarly) && this.items.length < input.length) {\n _addIssue(this, \"type\", dataset, config2, {\n input: input[this.items.length],\n expected: \"never\",\n path: [\n {\n type: \"array\",\n origin: \"value\",\n input,\n key: this.items.length,\n value: input[this.items.length]\n }\n ]\n });\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/string/string.ts\n// @__NO_SIDE_EFFECTS__\nfunction string(message2) {\n return {\n kind: \"schema\",\n type: \"string\",\n reference: string,\n expects: \"string\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (typeof dataset.value === \"string\") {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/symbol/symbol.ts\n// @__NO_SIDE_EFFECTS__\nfunction symbol(message2) {\n return {\n kind: \"schema\",\n type: \"symbol\",\n reference: symbol,\n expects: \"symbol\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (typeof dataset.value === \"symbol\") {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/tuple/tuple.ts\n// @__NO_SIDE_EFFECTS__\nfunction tuple(items, message2) {\n return {\n kind: \"schema\",\n type: \"tuple\",\n reference: tuple,\n expects: \"Array\",\n async: false,\n items,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n for (let key = 0; key < this.items.length; key++) {\n const value2 = input[key];\n const itemDataset = this.items[key][\"~run\"]({ value: value2 }, config2);\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/tuple/tupleAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction tupleAsync(items, message2) {\n return {\n kind: \"schema\",\n type: \"tuple\",\n reference: tupleAsync,\n expects: \"Array\",\n async: true,\n items,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n const itemDatasets = await Promise.all(\n this.items.map(async (item, key) => {\n const value2 = input[key];\n return [key, value2, await item[\"~run\"]({ value: value2 }, config2)];\n })\n );\n for (const [key, value2, itemDataset] of itemDatasets) {\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/tupleWithRest/tupleWithRest.ts\n// @__NO_SIDE_EFFECTS__\nfunction tupleWithRest(items, rest, message2) {\n return {\n kind: \"schema\",\n type: \"tuple_with_rest\",\n reference: tupleWithRest,\n expects: \"Array\",\n async: false,\n items,\n rest,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n for (let key = 0; key < this.items.length; key++) {\n const value2 = input[key];\n const itemDataset = this.items[key][\"~run\"]({ value: value2 }, config2);\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (let key = this.items.length; key < input.length; key++) {\n const value2 = input[key];\n const itemDataset = this.rest[\"~run\"]({ value: value2 }, config2);\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/tupleWithRest/tupleWithRestAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction tupleWithRestAsync(items, rest, message2) {\n return {\n kind: \"schema\",\n type: \"tuple_with_rest\",\n reference: tupleWithRestAsync,\n expects: \"Array\",\n async: true,\n items,\n rest,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (Array.isArray(input)) {\n dataset.typed = true;\n dataset.value = [];\n const [normalDatasets, restDatasets] = await Promise.all([\n // Parse schema of each normal item\n Promise.all(\n this.items.map(async (item, key) => {\n const value2 = input[key];\n return [\n key,\n value2,\n await item[\"~run\"]({ value: value2 }, config2)\n ];\n })\n ),\n // Parse other items with rest schema\n Promise.all(\n input.slice(this.items.length).map(async (value2, key) => {\n return [\n key + this.items.length,\n value2,\n await this.rest[\"~run\"]({ value: value2 }, config2)\n ];\n })\n )\n ]);\n for (const [key, value2, itemDataset] of normalDatasets) {\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n if (!dataset.issues || !config2.abortEarly) {\n for (const [key, value2, itemDataset] of restDatasets) {\n if (itemDataset.issues) {\n const pathItem = {\n type: \"array\",\n origin: \"value\",\n input,\n key,\n value: value2\n };\n for (const issue of itemDataset.issues) {\n if (issue.path) {\n issue.path.unshift(pathItem);\n } else {\n issue.path = [pathItem];\n }\n dataset.issues?.push(issue);\n }\n if (!dataset.issues) {\n dataset.issues = itemDataset.issues;\n }\n if (config2.abortEarly) {\n dataset.typed = false;\n break;\n }\n }\n if (!itemDataset.typed) {\n dataset.typed = false;\n }\n dataset.value.push(itemDataset.value);\n }\n }\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/undefined/undefined.ts\n// @__NO_SIDE_EFFECTS__\nfunction undefined_(message2) {\n return {\n kind: \"schema\",\n type: \"undefined\",\n reference: undefined_,\n expects: \"undefined\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === void 0) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/undefinedable/undefinedable.ts\n// @__NO_SIDE_EFFECTS__\nfunction undefinedable(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"undefinedable\",\n reference: undefinedable,\n expects: `(${wrapped.expects} | undefined)`,\n async: false,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === void 0) {\n if (this.default !== void 0) {\n dataset.value = getDefault(this, dataset, config2);\n }\n if (dataset.value === void 0) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/undefinedable/undefinedableAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction undefinedableAsync(wrapped, default_) {\n return {\n kind: \"schema\",\n type: \"undefinedable\",\n reference: undefinedableAsync,\n expects: `(${wrapped.expects} | undefined)`,\n async: true,\n wrapped,\n default: default_,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n if (dataset.value === void 0) {\n if (this.default !== void 0) {\n dataset.value = await getDefault(this, dataset, config2);\n }\n if (dataset.value === void 0) {\n dataset.typed = true;\n return dataset;\n }\n }\n return this.wrapped[\"~run\"](dataset, config2);\n }\n };\n}\n\n// src/schemas/union/utils/_subIssues/_subIssues.ts\n// @__NO_SIDE_EFFECTS__\nfunction _subIssues(datasets) {\n let issues;\n if (datasets) {\n for (const dataset of datasets) {\n if (issues) {\n issues.push(...dataset.issues);\n } else {\n issues = dataset.issues;\n }\n }\n }\n return issues;\n}\n\n// src/schemas/union/union.ts\n// @__NO_SIDE_EFFECTS__\nfunction union(options, message2) {\n return {\n kind: \"schema\",\n type: \"union\",\n reference: union,\n expects: _joinExpects(\n options.map((option) => option.expects),\n \"|\"\n ),\n async: false,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n let validDataset;\n let typedDatasets;\n let untypedDatasets;\n for (const schema of this.options) {\n const optionDataset = schema[\"~run\"]({ value: dataset.value }, config2);\n if (optionDataset.typed) {\n if (optionDataset.issues) {\n if (typedDatasets) {\n typedDatasets.push(optionDataset);\n } else {\n typedDatasets = [optionDataset];\n }\n } else {\n validDataset = optionDataset;\n break;\n }\n } else {\n if (untypedDatasets) {\n untypedDatasets.push(optionDataset);\n } else {\n untypedDatasets = [optionDataset];\n }\n }\n }\n if (validDataset) {\n return validDataset;\n }\n if (typedDatasets) {\n if (typedDatasets.length === 1) {\n return typedDatasets[0];\n }\n _addIssue(this, \"type\", dataset, config2, {\n issues: _subIssues(typedDatasets)\n });\n dataset.typed = true;\n } else if (untypedDatasets?.length === 1) {\n return untypedDatasets[0];\n } else {\n _addIssue(this, \"type\", dataset, config2, {\n issues: _subIssues(untypedDatasets)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/union/unionAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction unionAsync(options, message2) {\n return {\n kind: \"schema\",\n type: \"union\",\n reference: unionAsync,\n expects: _joinExpects(\n options.map((option) => option.expects),\n \"|\"\n ),\n async: true,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n let validDataset;\n let typedDatasets;\n let untypedDatasets;\n for (const schema of this.options) {\n const optionDataset = await schema[\"~run\"](\n { value: dataset.value },\n config2\n );\n if (optionDataset.typed) {\n if (optionDataset.issues) {\n if (typedDatasets) {\n typedDatasets.push(optionDataset);\n } else {\n typedDatasets = [optionDataset];\n }\n } else {\n validDataset = optionDataset;\n break;\n }\n } else {\n if (untypedDatasets) {\n untypedDatasets.push(optionDataset);\n } else {\n untypedDatasets = [optionDataset];\n }\n }\n }\n if (validDataset) {\n return validDataset;\n }\n if (typedDatasets) {\n if (typedDatasets.length === 1) {\n return typedDatasets[0];\n }\n _addIssue(this, \"type\", dataset, config2, {\n issues: _subIssues(typedDatasets)\n });\n dataset.typed = true;\n } else if (untypedDatasets?.length === 1) {\n return untypedDatasets[0];\n } else {\n _addIssue(this, \"type\", dataset, config2, {\n issues: _subIssues(untypedDatasets)\n });\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/unknown/unknown.ts\n// @__NO_SIDE_EFFECTS__\nfunction unknown() {\n return {\n kind: \"schema\",\n type: \"unknown\",\n reference: unknown,\n expects: \"unknown\",\n async: false,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset) {\n dataset.typed = true;\n return dataset;\n }\n };\n}\n\n// src/schemas/variant/variant.ts\n// @__NO_SIDE_EFFECTS__\nfunction variant(key, options, message2) {\n return {\n kind: \"schema\",\n type: \"variant\",\n reference: variant,\n expects: \"Object\",\n async: false,\n key,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n let outputDataset;\n let maxDiscriminatorPriority = 0;\n let invalidDiscriminatorKey = this.key;\n let expectedDiscriminators = [];\n const parseOptions = (variant2, allKeys) => {\n for (const schema of variant2.options) {\n if (schema.type === \"variant\") {\n parseOptions(schema, new Set(allKeys).add(schema.key));\n } else {\n let keysAreValid = true;\n let currentPriority = 0;\n for (const currentKey of allKeys) {\n const discriminatorSchema = schema.entries[currentKey];\n if (currentKey in input ? discriminatorSchema[\"~run\"](\n // @ts-expect-error\n { typed: false, value: input[currentKey] },\n { abortEarly: true }\n ).issues : discriminatorSchema.type !== \"exact_optional\" && discriminatorSchema.type !== \"optional\" && discriminatorSchema.type !== \"nullish\") {\n keysAreValid = false;\n if (invalidDiscriminatorKey !== currentKey && (maxDiscriminatorPriority < currentPriority || maxDiscriminatorPriority === currentPriority && currentKey in input && !(invalidDiscriminatorKey in input))) {\n maxDiscriminatorPriority = currentPriority;\n invalidDiscriminatorKey = currentKey;\n expectedDiscriminators = [];\n }\n if (invalidDiscriminatorKey === currentKey) {\n expectedDiscriminators.push(\n schema.entries[currentKey].expects\n );\n }\n break;\n }\n currentPriority++;\n }\n if (keysAreValid) {\n const optionDataset = schema[\"~run\"]({ value: input }, config2);\n if (!outputDataset || !outputDataset.typed && optionDataset.typed) {\n outputDataset = optionDataset;\n }\n }\n }\n if (outputDataset && !outputDataset.issues) {\n break;\n }\n }\n };\n parseOptions(this, /* @__PURE__ */ new Set([this.key]));\n if (outputDataset) {\n return outputDataset;\n }\n _addIssue(this, \"type\", dataset, config2, {\n // @ts-expect-error\n input: input[invalidDiscriminatorKey],\n expected: _joinExpects(expectedDiscriminators, \"|\"),\n path: [\n {\n type: \"object\",\n origin: \"value\",\n input,\n key: invalidDiscriminatorKey,\n // @ts-expect-error\n value: input[invalidDiscriminatorKey]\n }\n ]\n });\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/variant/variantAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction variantAsync(key, options, message2) {\n return {\n kind: \"schema\",\n type: \"variant\",\n reference: variantAsync,\n expects: \"Object\",\n async: true,\n key,\n options,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n const input = dataset.value;\n if (input && typeof input === \"object\") {\n let outputDataset;\n let maxDiscriminatorPriority = 0;\n let invalidDiscriminatorKey = this.key;\n let expectedDiscriminators = [];\n const parseOptions = async (variant2, allKeys) => {\n for (const schema of variant2.options) {\n if (schema.type === \"variant\") {\n await parseOptions(schema, new Set(allKeys).add(schema.key));\n } else {\n let keysAreValid = true;\n let currentPriority = 0;\n for (const currentKey of allKeys) {\n const discriminatorSchema = schema.entries[currentKey];\n if (currentKey in input ? (await discriminatorSchema[\"~run\"](\n // @ts-expect-error\n { typed: false, value: input[currentKey] },\n { abortEarly: true }\n )).issues : discriminatorSchema.type !== \"exact_optional\" && discriminatorSchema.type !== \"optional\" && discriminatorSchema.type !== \"nullish\") {\n keysAreValid = false;\n if (invalidDiscriminatorKey !== currentKey && (maxDiscriminatorPriority < currentPriority || maxDiscriminatorPriority === currentPriority && currentKey in input && !(invalidDiscriminatorKey in input))) {\n maxDiscriminatorPriority = currentPriority;\n invalidDiscriminatorKey = currentKey;\n expectedDiscriminators = [];\n }\n if (invalidDiscriminatorKey === currentKey) {\n expectedDiscriminators.push(\n schema.entries[currentKey].expects\n );\n }\n break;\n }\n currentPriority++;\n }\n if (keysAreValid) {\n const optionDataset = await schema[\"~run\"](\n { value: input },\n config2\n );\n if (!outputDataset || !outputDataset.typed && optionDataset.typed) {\n outputDataset = optionDataset;\n }\n }\n }\n if (outputDataset && !outputDataset.issues) {\n break;\n }\n }\n };\n await parseOptions(this, /* @__PURE__ */ new Set([this.key]));\n if (outputDataset) {\n return outputDataset;\n }\n _addIssue(this, \"type\", dataset, config2, {\n // @ts-expect-error\n input: input[invalidDiscriminatorKey],\n expected: _joinExpects(expectedDiscriminators, \"|\"),\n path: [\n {\n type: \"object\",\n origin: \"value\",\n input,\n key: invalidDiscriminatorKey,\n // @ts-expect-error\n value: input[invalidDiscriminatorKey]\n }\n ]\n });\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/schemas/void/void.ts\n// @__NO_SIDE_EFFECTS__\nfunction void_(message2) {\n return {\n kind: \"schema\",\n type: \"void\",\n reference: void_,\n expects: \"void\",\n async: false,\n message: message2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n if (dataset.value === void 0) {\n dataset.typed = true;\n } else {\n _addIssue(this, \"type\", dataset, config2);\n }\n return dataset;\n }\n };\n}\n\n// src/methods/keyof/keyof.ts\n// @__NO_SIDE_EFFECTS__\nfunction keyof(schema, message2) {\n return picklist(Object.keys(schema.entries), message2);\n}\n\n// src/methods/message/message.ts\n// @__NO_SIDE_EFFECTS__\nfunction message(schema, message_) {\n return {\n ...schema,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n return schema[\"~run\"](dataset, { ...config2, message: message_ });\n }\n };\n}\n\n// src/methods/omit/omit.ts\n// @__NO_SIDE_EFFECTS__\nfunction omit(schema, keys) {\n const entries2 = {\n ...schema.entries\n };\n for (const key of keys) {\n delete entries2[key];\n }\n return {\n ...schema,\n entries: entries2,\n get \"~standard\"() {\n return _getStandardProps(this);\n }\n };\n}\n\n// src/methods/parse/parse.ts\nfunction parse(schema, input, config2) {\n const dataset = schema[\"~run\"]({ value: input }, getGlobalConfig(config2));\n if (dataset.issues) {\n throw new ValiError(dataset.issues);\n }\n return dataset.value;\n}\n\n// src/methods/parse/parseAsync.ts\nasync function parseAsync(schema, input, config2) {\n const dataset = await schema[\"~run\"](\n { value: input },\n getGlobalConfig(config2)\n );\n if (dataset.issues) {\n throw new ValiError(dataset.issues);\n }\n return dataset.value;\n}\n\n// src/methods/parser/parser.ts\n// @__NO_SIDE_EFFECTS__\nfunction parser(schema, config2) {\n const func = (input) => parse(schema, input, config2);\n func.schema = schema;\n func.config = config2;\n return func;\n}\n\n// src/methods/parser/parserAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction parserAsync(schema, config2) {\n const func = (input) => parseAsync(schema, input, config2);\n func.schema = schema;\n func.config = config2;\n return func;\n}\n\n// src/methods/partial/partial.ts\n// @__NO_SIDE_EFFECTS__\nfunction partial(schema, keys) {\n const entries2 = {};\n for (const key in schema.entries) {\n entries2[key] = !keys || keys.includes(key) ? optional(schema.entries[key]) : schema.entries[key];\n }\n return {\n ...schema,\n entries: entries2,\n get \"~standard\"() {\n return _getStandardProps(this);\n }\n };\n}\n\n// src/methods/partial/partialAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction partialAsync(schema, keys) {\n const entries2 = {};\n for (const key in schema.entries) {\n entries2[key] = !keys || keys.includes(key) ? optionalAsync(schema.entries[key]) : schema.entries[key];\n }\n return {\n ...schema,\n entries: entries2,\n get \"~standard\"() {\n return _getStandardProps(this);\n }\n };\n}\n\n// src/methods/pick/pick.ts\n// @__NO_SIDE_EFFECTS__\nfunction pick(schema, keys) {\n const entries2 = {};\n for (const key of keys) {\n entries2[key] = schema.entries[key];\n }\n return {\n ...schema,\n entries: entries2,\n get \"~standard\"() {\n return _getStandardProps(this);\n }\n };\n}\n\n// src/methods/pipe/pipe.ts\n// @__NO_SIDE_EFFECTS__\nfunction pipe(...pipe2) {\n return {\n ...pipe2[0],\n pipe: pipe2,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n \"~run\"(dataset, config2) {\n for (const item of pipe2) {\n if (item.kind !== \"metadata\") {\n if (dataset.issues && (item.kind === \"schema\" || item.kind === \"transformation\")) {\n dataset.typed = false;\n break;\n }\n if (!dataset.issues || !config2.abortEarly && !config2.abortPipeEarly) {\n dataset = item[\"~run\"](dataset, config2);\n }\n }\n }\n return dataset;\n }\n };\n}\n\n// src/methods/pipe/pipeAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction pipeAsync(...pipe2) {\n return {\n ...pipe2[0],\n pipe: pipe2,\n async: true,\n get \"~standard\"() {\n return _getStandardProps(this);\n },\n async \"~run\"(dataset, config2) {\n for (const item of pipe2) {\n if (item.kind !== \"metadata\") {\n if (dataset.issues && (item.kind === \"schema\" || item.kind === \"transformation\")) {\n dataset.typed = false;\n break;\n }\n if (!dataset.issues || !config2.abortEarly && !config2.abortPipeEarly) {\n dataset = await item[\"~run\"](dataset, config2);\n }\n }\n }\n return dataset;\n }\n };\n}\n\n// src/methods/required/required.ts\n// @__NO_SIDE_EFFECTS__\nfunction required(schema, arg2, arg3) {\n const keys = Array.isArray(arg2) ? arg2 : void 0;\n const message2 = Array.isArray(arg2) ? arg3 : arg2;\n const entries2 = {};\n for (const key in schema.entries) {\n entries2[key] = !keys || keys.includes(key) ? nonOptional(schema.entries[key], message2) : schema.entries[key];\n }\n return {\n ...schema,\n entries: entries2,\n get \"~standard\"() {\n return _getStandardProps(this);\n }\n };\n}\n\n// src/methods/required/requiredAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction requiredAsync(schema, arg2, arg3) {\n const keys = Array.isArray(arg2) ? arg2 : void 0;\n const message2 = Array.isArray(arg2) ? arg3 : arg2;\n const entries2 = {};\n for (const key in schema.entries) {\n entries2[key] = !keys || keys.includes(key) ? nonOptionalAsync(schema.entries[key], message2) : schema.entries[key];\n }\n return {\n ...schema,\n entries: entries2,\n get \"~standard\"() {\n return _getStandardProps(this);\n }\n };\n}\n\n// src/methods/safeParse/safeParse.ts\n// @__NO_SIDE_EFFECTS__\nfunction safeParse(schema, input, config2) {\n const dataset = schema[\"~run\"]({ value: input }, getGlobalConfig(config2));\n return {\n typed: dataset.typed,\n success: !dataset.issues,\n output: dataset.value,\n issues: dataset.issues\n };\n}\n\n// src/methods/safeParse/safeParseAsync.ts\n// @__NO_SIDE_EFFECTS__\nasync function safeParseAsync(schema, input, config2) {\n const dataset = await schema[\"~run\"](\n { value: input },\n getGlobalConfig(config2)\n );\n return {\n typed: dataset.typed,\n success: !dataset.issues,\n output: dataset.value,\n issues: dataset.issues\n };\n}\n\n// src/methods/safeParser/safeParser.ts\n// @__NO_SIDE_EFFECTS__\nfunction safeParser(schema, config2) {\n const func = (input) => safeParse(schema, input, config2);\n func.schema = schema;\n func.config = config2;\n return func;\n}\n\n// src/methods/safeParser/safeParserAsync.ts\n// @__NO_SIDE_EFFECTS__\nfunction safeParserAsync(schema, config2) {\n const func = (input) => safeParseAsync(schema, input, config2);\n func.schema = schema;\n func.config = config2;\n return func;\n}\n\n// src/methods/summarize/summarize.ts\n// @__NO_SIDE_EFFECTS__\nfunction summarize(issues) {\n let summary = \"\";\n for (const issue of issues) {\n if (summary) {\n summary += \"\\n\";\n }\n summary += `\\xD7 ${issue.message}`;\n const dotPath = getDotPath(issue);\n if (dotPath) {\n summary += `\n \\u2192 at ${dotPath}`;\n }\n }\n return summary;\n}\n\n// src/methods/unwrap/unwrap.ts\n// @__NO_SIDE_EFFECTS__\nfunction unwrap(schema) {\n return schema.wrapped;\n}\nexport {\n BASE64_REGEX,\n BIC_REGEX,\n CUID2_REGEX,\n DECIMAL_REGEX,\n DIGITS_REGEX,\n EMAIL_REGEX,\n EMOJI_REGEX,\n HEXADECIMAL_REGEX,\n HEX_COLOR_REGEX,\n IMEI_REGEX,\n IPV4_REGEX,\n IPV6_REGEX,\n IP_REGEX,\n ISO_DATE_REGEX,\n ISO_DATE_TIME_REGEX,\n ISO_TIMESTAMP_REGEX,\n ISO_TIME_REGEX,\n ISO_TIME_SECOND_REGEX,\n ISO_WEEK_REGEX,\n MAC48_REGEX,\n MAC64_REGEX,\n MAC_REGEX,\n NANO_ID_REGEX,\n OCTAL_REGEX,\n RFC_EMAIL_REGEX,\n SLUG_REGEX,\n ULID_REGEX,\n UUID_REGEX,\n ValiError,\n _addIssue,\n _getByteCount,\n _getGraphemeCount,\n _getLastMetadata,\n _getStandardProps,\n _getWordCount,\n _isLuhnAlgo,\n _isValidObjectKey,\n _joinExpects,\n _stringify,\n any,\n args,\n argsAsync,\n array,\n arrayAsync,\n assert,\n awaitAsync,\n base64,\n bic,\n bigint,\n blob,\n boolean,\n brand,\n bytes,\n check,\n checkAsync,\n checkItems,\n checkItemsAsync,\n config,\n creditCard,\n cuid2,\n custom,\n customAsync,\n date,\n decimal,\n deleteGlobalConfig,\n deleteGlobalMessage,\n deleteSchemaMessage,\n deleteSpecificMessage,\n description,\n digits,\n email,\n emoji,\n empty,\n endsWith,\n entries,\n entriesFromList,\n entriesFromObjects,\n enum_ as enum,\n enum_,\n everyItem,\n exactOptional,\n exactOptionalAsync,\n excludes,\n fallback,\n fallbackAsync,\n file,\n filterItems,\n findItem,\n finite,\n flatten,\n flavor,\n forward,\n forwardAsync,\n function_ as function,\n function_,\n getDefault,\n getDefaults,\n getDefaultsAsync,\n getDescription,\n getDotPath,\n getFallback,\n getFallbacks,\n getFallbacksAsync,\n getGlobalConfig,\n getGlobalMessage,\n getMetadata,\n getSchemaMessage,\n getSpecificMessage,\n getTitle,\n graphemes,\n gtValue,\n hash,\n hexColor,\n hexadecimal,\n imei,\n includes,\n instance,\n integer,\n intersect,\n intersectAsync,\n ip,\n ipv4,\n ipv6,\n is,\n isOfKind,\n isOfType,\n isValiError,\n isoDate,\n isoDateTime,\n isoTime,\n isoTimeSecond,\n isoTimestamp,\n isoWeek,\n keyof,\n lazy,\n lazyAsync,\n length,\n literal,\n looseObject,\n looseObjectAsync,\n looseTuple,\n looseTupleAsync,\n ltValue,\n mac,\n mac48,\n mac64,\n map,\n mapAsync,\n mapItems,\n maxBytes,\n maxEntries,\n maxGraphemes,\n maxLength,\n maxSize,\n maxValue,\n maxWords,\n message,\n metadata,\n mimeType,\n minBytes,\n minEntries,\n minGraphemes,\n minLength,\n minSize,\n minValue,\n minWords,\n multipleOf,\n nan,\n nanoid,\n never,\n nonEmpty,\n nonNullable,\n nonNullableAsync,\n nonNullish,\n nonNullishAsync,\n nonOptional,\n nonOptionalAsync,\n normalize,\n notBytes,\n notEntries,\n notGraphemes,\n notLength,\n notSize,\n notValue,\n notValues,\n notWords,\n null_ as null,\n null_,\n nullable,\n nullableAsync,\n nullish,\n nullishAsync,\n number,\n object,\n objectAsync,\n objectWithRest,\n objectWithRestAsync,\n octal,\n omit,\n optional,\n optionalAsync,\n parse,\n parseAsync,\n parseJson,\n parser,\n parserAsync,\n partial,\n partialAsync,\n partialCheck,\n partialCheckAsync,\n pick,\n picklist,\n pipe,\n pipeAsync,\n promise,\n rawCheck,\n rawCheckAsync,\n rawTransform,\n rawTransformAsync,\n readonly,\n record,\n recordAsync,\n reduceItems,\n regex,\n required,\n requiredAsync,\n returns,\n returnsAsync,\n rfcEmail,\n safeInteger,\n safeParse,\n safeParseAsync,\n safeParser,\n safeParserAsync,\n set,\n setAsync,\n setGlobalConfig,\n setGlobalMessage,\n setSchemaMessage,\n setSpecificMessage,\n size,\n slug,\n someItem,\n sortItems,\n startsWith,\n strictObject,\n strictObjectAsync,\n strictTuple,\n strictTupleAsync,\n string,\n stringifyJson,\n summarize,\n symbol,\n title,\n toLowerCase,\n toMaxValue,\n toMinValue,\n toUpperCase,\n transform,\n transformAsync,\n trim,\n trimEnd,\n trimStart,\n tuple,\n tupleAsync,\n tupleWithRest,\n tupleWithRestAsync,\n ulid,\n undefined_ as undefined,\n undefined_,\n undefinedable,\n undefinedableAsync,\n union,\n unionAsync,\n unknown,\n unwrap,\n url,\n uuid,\n value,\n values,\n variant,\n variantAsync,\n void_ as void,\n void_,\n words\n};\n","/** Types d'Erreurs liées aux adresses WooCommerce. */\n\nexport class ErreurAdresseInvalide extends Error {\n problemes: Record;\n\n constructor(problemes: Record) {\n super(\"Le ou les adresses fournies sont invalides.\");\n this.name = \"ErreurAdresseInvalide\";\n this.problemes = problemes;\n }\n}\n","/**\n * Fonctions pour la création d'Erreurs.\n */\n\nimport { captureException } from \"@sentry/browser\";\nimport { ValiError } from \"valibot\";\n\nimport type { WCErrorBody } from \"./types/api/erreurs\";\n\nimport { ErreurAdresseInvalide } from \"./erreurs/adresses\";\n\n/* Messages d'erreur */\nexport const ERREUR_SYNTAXE_INVALIDE = (selecteur: string): string => `Le selecteur \"${selecteur}\" est invalide`;\nexport const ERREUR_DOM_INEXISTANT = (selecteur: string): string =>\n `La requête \"${selecteur}\" n'a retourné aucun Élément.`;\n\n/* Création d'erreurs */\nexport const creeSyntaxError = (message: string): SyntaxError => new SyntaxError(message);\n\n/* Types d'erreurs */\nexport class BadRequestError extends Error {\n constructor(message = \"400 BadRequestError\") {\n super(message);\n this.name = \"BadRequestError\";\n }\n}\nexport class CleNonTrouveError extends Error {\n constructor(message: unknown) {\n super(JSON.stringify(message));\n this.name = \"CleNonTrouveError\";\n }\n}\nexport class DOMElementAbsentError extends Error {\n constructor(message: unknown) {\n super(JSON.stringify(message));\n this.name = \"DOMElementAbsentError\";\n }\n}\nexport class ForbiddenError extends Error {\n constructor(message = \"403 ForbiddenError\") {\n super(message);\n this.name = \"ForbiddenError\";\n }\n}\nexport class NonExistingKeyError extends Error {\n constructor(message: unknown) {\n super(JSON.stringify(message));\n this.name = \"NonExistingKeyError\";\n }\n}\nexport class NotFoundError extends Error {\n constructor(message = \"404 NotFoundError\") {\n super(message);\n this.name = \"NotFoundError\";\n }\n}\nexport class ServerError extends Error {\n constructor(message = \"500 ServerError\") {\n super(message);\n this.name = \"ServerError\";\n }\n}\nexport class UnauthorizedError extends Error {\n constructor(message = \"401 UnauthorizedError\") {\n super(message);\n this.name = \"UnauthorizedError\";\n }\n}\nexport class UnknownError extends Error {\n constructor(message: unknown) {\n super(JSON.stringify(message));\n this.name = \"UnknownError\";\n }\n}\n\n/* Fonction utilitaire pour créer ou lever des Erreurs */\nexport const Erreur = (message: string): Error => new Error(message);\nexport const ErreurInconnue = (erreur: unknown): UnknownError => new UnknownError(erreur);\nexport const ErreurEntreeInexistante = (message: string): NonExistingKeyError => new NonExistingKeyError(message);\n\nexport const leveErreur = (erreur: E): never => {\n throw erreur;\n};\nexport const leveBadRequestError = (erreur: WCErrorBody): never => {\n throw new BadRequestError(`(${erreur.code}) ${erreur.message}`);\n};\nexport const leveUnauthorizedError = (erreur: WCErrorBody): never => {\n throw new UnauthorizedError(`(${erreur.code}) ${erreur.message}`);\n};\nexport const leveNotFoundError = (erreur: WCErrorBody): never => {\n throw new NotFoundError(`(${erreur.code}) ${erreur.message}`);\n};\nexport const leveServerError = (message: string): never => {\n throw new ServerError(message);\n};\nexport const leveUnknownError = (erreur: unknown): never => {\n throw new UnknownError(erreur);\n};\nexport const leveNonExistingKeyError = (message: string): never => {\n throw new NonExistingKeyError(message);\n};\n\n/**\n * Reporte une Erreur, sous forme d'erreur console et au service GlitchTip.\n *\n * @param erreur\n * @returns L'ID Sentry de l'évènement capturé.\n */\nexport const reporteErreur = (erreur: E): string => captureException(erreur);\n\n/**\n * Reporte une Erreur, sous forme d'erreur console et au service GlitchTip, puis la lève sous forme\n * d'Exception.\n *\n * @param erreur\n * @returns never Lève une Erreur et ne retourne donc rien.\n */\nexport const reporteEtLeveErreur = (erreur: E): never => {\n reporteErreur(erreur);\n throw erreur;\n};\n\nexport const reporteEtJournaliseErreur = (erreur: E): void => {\n reporteErreur(erreur);\n console.error(erreur);\n if (erreur instanceof ValiError) console.error(erreur.issues);\n if (erreur instanceof ErreurAdresseInvalide) console.error(erreur.problemes);\n};\n\nexport const reporteEtRetourneErreur = (erreur: E): E => {\n reporteErreur(erreur);\n return erreur;\n};\n","import { A, G, pipe } from \"@mobily/ts-belt\";\nimport { Either, identity, Left, Right } from \"purify-ts\";\n\nimport type { ParentElement } from \"./types/dom.d.ts\";\n\nimport { ATTRIBUT_CHARGEMENT, ATTRIBUT_DESACTIVE } from \"../constantes/dom.ts\";\nimport { logger } from \"../journalisation.ts\";\nimport { lanceAnimationCycleLoading } from \"./animations.ts\";\nimport {\n BadRequestError,\n creeSyntaxError,\n ERREUR_DOM_INEXISTANT,\n ERREUR_SYNTAXE_INVALIDE,\n ForbiddenError,\n NotFoundError,\n reporteEtLeveErreur,\n ServerError,\n UnauthorizedError,\n} from \"./erreurs\";\n\nexport const recupereElementAvecSelecteur =\n (parent: ParentElement) => (selecteur: string): Either =>\n Either\n // Retourne une SyntaxError dans un Left si le sélecteur est invalide\n .encase(() => parent.querySelector(selecteur))\n // Transforme le Left en une erreur plus sympathique\n .mapLeft(_ => creeSyntaxError(ERREUR_SYNTAXE_INVALIDE(selecteur)))\n // Retourne une SyntaxError si l'Élément est null\n .chain((e: E | null) => G.isNotNullable(e) ? Right(e) : Left(creeSyntaxError(ERREUR_DOM_INEXISTANT(selecteur))));\n\nexport const getDOMElementsWithSelector =\n (parent: ParentElement) => (selecteur: string): Either> =>\n Either\n // Retourne une SyntaxError dans un Left si le sélecteur est invalide\n .encase(() => pipe(parent.querySelectorAll(selecteur), Array.from))\n // Transforme le Left en une erreur plus sympathique\n .mapLeft(_ => creeSyntaxError(ERREUR_SYNTAXE_INVALIDE(selecteur)))\n // Retourne une SyntaxError si le tableau est vide\n .chain((e: Array) => A.isEmpty(e) ? Left(creeSyntaxError(ERREUR_DOM_INEXISTANT(selecteur))) : Right(e));\n\nexport const recupereElementOuLeve = (elementOuErreur: Either): E =>\n elementOuErreur.caseOf({\n Left: reporteEtLeveErreur,\n Right: identity,\n });\n\nexport const recupereElementsOuLeve = (\n elementsOuErreur: Either>,\n): Array =>\n elementsOuErreur.caseOf({\n Left: reporteEtLeveErreur,\n Right: identity,\n });\n\nexport const majElementInnerHtml = (element: T) => (innerHtml: string) => {\n element.innerHTML = innerHtml;\n return element;\n};\n\n// Merci facon (https://github.com/terkelg/facon)\nexport const html = (strings: TemplateStringsArray, ...args: Array) =>\n pipe(\n document.createElement(\"template\"),\n template =>\n majElementInnerHtml(template)(args.reduce((prev, value, i) => prev + value + strings[i + 1], strings[0])),\n template => template.content,\n );\n\n/**\n * Convertis une chaîne JSON en un objet JavaScript sous forme d'`Either`.\n * @param chaine La chaîne à convertir.\n * @returns Un `Either` avec une `SyntaxError` si la chaîne est invalide, un objet JS sinon\n * (`Right`).\n */\nexport const safeJsonParse = (chaine: string): Either =>\n Either.encase(() => JSON.parse(chaine));\n\n/**\n * Vérifie qu'un sélecteur s'applique à l'élément DOM d'une cible d'événement (un `EventTarget`) donnée.\n * La fonction agit comme un garde de type.\n *\n * @returns Un booléen\n */\nexport const targetMatchesSelector = (\n cible: EventTarget | null,\n selecteur: string,\n): cible is E => cible !== null && (cible as HTMLElement).matches(selecteur);\n\nexport const recupereElementsDocumentEither: (\n selecteur: string,\n) => Either> = getDOMElementsWithSelector(document);\n\nexport const recupereElementDocumentEither: (\n selecteur: string,\n) => Either = recupereElementAvecSelecteur(document);\n\n/**\n * Fonction utilitaire pour récupérer un Élément selon un sélecteur au sein du Document.\n *\n * @param selecteur Le sélecteur de l'Élément recherché.\n * @throws Une SyntaxError si l'Élément n'est pas trouvé.\n * @returns Un Élément.\n */\nexport const mustGetEleInDocument = (selecteur: string): E =>\n pipe(\n recupereElementDocumentEither(selecteur),\n recupereElementOuLeve,\n );\n\nexport const mustGetEleInParent = (parent: ParentElement) => (selector: string) =>\n pipe(recupereElementAvecSelecteur(parent)(selector), recupereElementOuLeve);\n\n/**\n * Fonction utilitaire pour récupérer des Éléments selon un sélecteur au sein du Document.\n *\n * @param selecteur Le sélecteur des Éléments recherchés.\n * @throws Une SyntaxError si aucun Élément n'est trouvé.\n * @returns Un tableau d'Éléments.\n */\nexport const mustGetElesInDocument = (selecteur: string): Array =>\n pipe(\n recupereElementsDocumentEither(selecteur),\n recupereElementsOuLeve,\n );\n\nexport const setButtonLoadingState = (button: HTMLButtonElement, isLoading: boolean): void => {\n logger.debug(\"majEtatChargementBouton\", button, isLoading);\n if (isLoading) {\n // Désactive le Bouton pour empêcher des requêtes concurrentes\n button.setAttribute(ATTRIBUT_DESACTIVE, \"\");\n button.setAttribute(ATTRIBUT_CHARGEMENT, \"\");\n // Lance un cycle d'animation sur le texte de chargement\n lanceAnimationCycleLoading(button, 500);\n } else {\n // Désactive l'animation de chargement et rend le Bouton de nouveau cliquable\n button.removeAttribute(ATTRIBUT_CHARGEMENT);\n button.removeAttribute(ATTRIBUT_DESACTIVE);\n }\n};\n\nexport const estErreurHttp = (erreur: unknown) =>\n erreur instanceof BadRequestError\n || erreur instanceof ForbiddenError\n || erreur instanceof NotFoundError\n || erreur instanceof ServerError\n || erreur instanceof UnauthorizedError;\n\nexport const estErreurFetch = (erreur: unknown) =>\n erreur instanceof DOMException\n || erreur instanceof TypeError\n || erreur instanceof Error;\n"],"x_google_ignoreList":[0,1,2,3,4,5,6,8,9,10,12],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js b/web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js new file mode 100644 index 00000000..0220332d --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js @@ -0,0 +1,2718 @@ +//#region node_modules/@mobily/ts-belt/dist/pipe.mjs +function pipe() { + let e = arguments[0]; + for (let t = 1, p = arguments.length; t < p; t++) e = arguments[t](e); + return e; +} + +//#endregion +//#region node_modules/vite-plugin-node-polyfills/shims/global/dist/index.js +var global = globalThis || self; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/debug-build.js +/** +* This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code. +* +* ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking. +*/ +var DEBUG_BUILD = typeof __SENTRY_DEBUG__ === "undefined" || __SENTRY_DEBUG__; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/worldwide.js +/** Internal global with common properties and Sentry extensions */ +/** Get's the global object for the current JavaScript runtime */ +var GLOBAL_OBJ = globalThis; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/version.js +var SDK_VERSION = "10.22.0"; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/carrier.js +/** +* An object that contains globally accessible properties and maintains a scope stack. +* @hidden +*/ +/** +* Returns the global shim registry. +* +* FIXME: This function is problematic, because despite always returning a valid Carrier, +* it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check +* at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there. +**/ +function getMainCarrier() { + getSentryCarrier(GLOBAL_OBJ); + return GLOBAL_OBJ; +} +/** Will either get the existing sentry carrier, or create a new one. */ +function getSentryCarrier(carrier) { + const __SENTRY__ = carrier.__SENTRY__ = carrier.__SENTRY__ || {}; + __SENTRY__.version = __SENTRY__.version || "10.22.0"; + return __SENTRY__[SDK_VERSION] = __SENTRY__["10.22.0"] || {}; +} +/** +* Returns a global singleton contained in the global `__SENTRY__[]` object. +* +* If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory +* function and added to the `__SENTRY__` object. +* +* @param name name of the global singleton on __SENTRY__ +* @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__` +* @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value +* @returns the singleton +*/ +function getGlobalSingleton(name, creator, obj = GLOBAL_OBJ) { + const __SENTRY__ = obj.__SENTRY__ = obj.__SENTRY__ || {}; + const carrier = __SENTRY__[SDK_VERSION] = __SENTRY__["10.22.0"] || {}; + return carrier[name] || (carrier[name] = creator()); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/debug-logger.js +var CONSOLE_LEVELS = [ + "debug", + "info", + "warn", + "error", + "log", + "assert", + "trace" +]; +/** Prefix for logging strings */ +var PREFIX = "Sentry Logger "; +/** This may be mutated by the console instrumentation. */ +var originalConsoleMethods = {}; +/** +* Temporarily disable sentry console instrumentations. +* +* @param callback The function to run against the original `console` messages +* @returns The results of the callback +*/ +function consoleSandbox(callback) { + if (!("console" in GLOBAL_OBJ)) return callback(); + const console$1 = GLOBAL_OBJ.console; + const wrappedFuncs = {}; + const wrappedLevels = Object.keys(originalConsoleMethods); + wrappedLevels.forEach((level) => { + const originalConsoleMethod = originalConsoleMethods[level]; + wrappedFuncs[level] = console$1[level]; + console$1[level] = originalConsoleMethod; + }); + try { + return callback(); + } finally { + wrappedLevels.forEach((level) => { + console$1[level] = wrappedFuncs[level]; + }); + } +} +function enable() { + _getLoggerSettings().enabled = true; +} +function disable() { + _getLoggerSettings().enabled = false; +} +function isEnabled() { + return _getLoggerSettings().enabled; +} +function log(...args) { + _maybeLog("log", ...args); +} +function warn(...args) { + _maybeLog("warn", ...args); +} +function error(...args) { + _maybeLog("error", ...args); +} +function _maybeLog(level, ...args) { + if (!DEBUG_BUILD) return; + if (isEnabled()) consoleSandbox(() => { + GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args); + }); +} +function _getLoggerSettings() { + if (!DEBUG_BUILD) return { enabled: false }; + return getGlobalSingleton("loggerSettings", () => ({ enabled: false })); +} +/** +* This is a logger singleton which either logs things or no-ops if logging is not enabled. +*/ +var debug = { + enable, + disable, + isEnabled, + log, + warn, + error +}; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/stacktrace.js +var STACKTRACE_FRAME_LIMIT = 50; +var UNKNOWN_FUNCTION = "?"; +var WEBPACK_ERROR_REGEXP = /\(error: (.*)\)/; +var STRIP_FRAME_REGEXP = /captureMessage|captureException/; +/** +* Creates a stack parser with the supplied line parsers +* +* StackFrames are returned in the correct order for Sentry Exception +* frames and with Sentry SDK internal frames removed from the top and bottom +* +*/ +function createStackParser(...parsers) { + const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map((p) => p[1]); + return (stack, skipFirstLines = 0, framesToPop = 0) => { + const frames = []; + const lines = stack.split("\n"); + for (let i = skipFirstLines; i < lines.length; i++) { + let line = lines[i]; + if (line.length > 1024) line = line.slice(0, 1024); + const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, "$1") : line; + if (cleanedLine.match(/\S*Error: /)) continue; + for (const parser of sortedParsers) { + const frame = parser(cleanedLine); + if (frame) { + frames.push(frame); + break; + } + } + if (frames.length >= STACKTRACE_FRAME_LIMIT + framesToPop) break; + } + return stripSentryFramesAndReverse(frames.slice(framesToPop)); + }; +} +/** +* Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames. +* Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the +* function that caused the crash is the last frame in the array. +* @hidden +*/ +function stripSentryFramesAndReverse(stack) { + if (!stack.length) return []; + const localStack = Array.from(stack); + if (/sentryWrapped/.test(getLastStackFrame(localStack).function || "")) localStack.pop(); + localStack.reverse(); + if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || "")) { + localStack.pop(); + if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || "")) localStack.pop(); + } + return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map((frame) => ({ + ...frame, + filename: frame.filename || getLastStackFrame(localStack).filename, + function: frame.function || "?" + })); +} +function getLastStackFrame(arr) { + return arr[arr.length - 1] || {}; +} +var defaultFunctionName = ""; +/** +* Safely extract function name from itself +*/ +function getFunctionName(fn) { + try { + if (!fn || typeof fn !== "function") return defaultFunctionName; + return fn.name || defaultFunctionName; + } catch { + return defaultFunctionName; + } +} +/** +* Get's stack frames from an event without needing to check for undefined properties. +*/ +function getFramesFromEvent(event) { + const exception = event.exception; + if (exception) { + const frames = []; + try { + exception.values.forEach((value) => { + if (value.stacktrace.frames) frames.push(...value.stacktrace.frames); + }); + return frames; + } catch { + return; + } + } +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/is.js +var objectToString = Object.prototype.toString; +/** +* Checks whether given value's type is one of a few Error or Error-like +* {@link isError}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isError(wat) { + switch (objectToString.call(wat)) { + case "[object Error]": + case "[object Exception]": + case "[object DOMException]": + case "[object WebAssembly.Exception]": return true; + default: return isInstanceOf(wat, Error); + } +} +/** +* Checks whether given value is an instance of the given built-in class. +* +* @param wat The value to be checked +* @param className +* @returns A boolean representing the result. +*/ +function isBuiltin(wat, className) { + return objectToString.call(wat) === `[object ${className}]`; +} +/** +* Checks whether given value's type is ErrorEvent +* {@link isErrorEvent}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isErrorEvent(wat) { + return isBuiltin(wat, "ErrorEvent"); +} +/** +* Checks whether given value's type is DOMError +* {@link isDOMError}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isDOMError(wat) { + return isBuiltin(wat, "DOMError"); +} +/** +* Checks whether given value's type is DOMException +* {@link isDOMException}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isDOMException(wat) { + return isBuiltin(wat, "DOMException"); +} +/** +* Checks whether given value's type is a string +* {@link isString}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isString(wat) { + return isBuiltin(wat, "String"); +} +/** +* Checks whether given string is parameterized +* {@link isParameterizedString}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isParameterizedString(wat) { + return typeof wat === "object" && wat !== null && "__sentry_template_string__" in wat && "__sentry_template_values__" in wat; +} +/** +* Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol) +* {@link isPrimitive}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isPrimitive(wat) { + return wat === null || isParameterizedString(wat) || typeof wat !== "object" && typeof wat !== "function"; +} +/** +* Checks whether given value's type is an object literal, or a class instance. +* {@link isPlainObject}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isPlainObject(wat) { + return isBuiltin(wat, "Object"); +} +/** +* Checks whether given value's type is an Event instance +* {@link isEvent}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isEvent(wat) { + return typeof Event !== "undefined" && isInstanceOf(wat, Event); +} +/** +* Checks whether given value's type is an Element instance +* {@link isElement}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isElement(wat) { + return typeof Element !== "undefined" && isInstanceOf(wat, Element); +} +/** +* Checks whether given value's type is an regexp +* {@link isRegExp}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isRegExp(wat) { + return isBuiltin(wat, "RegExp"); +} +/** +* Checks whether given value has a then function. +* @param wat A value to be checked. +*/ +function isThenable(wat) { + return Boolean(wat?.then && typeof wat.then === "function"); +} +/** +* Checks whether given value's type is a SyntheticEvent +* {@link isSyntheticEvent}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isSyntheticEvent(wat) { + return isPlainObject(wat) && "nativeEvent" in wat && "preventDefault" in wat && "stopPropagation" in wat; +} +/** +* Checks whether given value's type is an instance of provided constructor. +* {@link isInstanceOf}. +* +* @param wat A value to be checked. +* @param base A constructor to be used in a check. +* @returns A boolean representing the result. +*/ +function isInstanceOf(wat, base) { + try { + return wat instanceof base; + } catch { + return false; + } +} +/** +* Checks whether given value's type is a Vue ViewModel. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isVueViewModel(wat) { + return !!(typeof wat === "object" && wat !== null && (wat.__isVue || wat._isVue)); +} +/** +* Checks whether the given parameter is a Standard Web API Request instance. +* +* Returns false if Request is not available in the current runtime. +*/ +function isRequest(request) { + return typeof Request !== "undefined" && isInstanceOf(request, Request); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/browser.js +var WINDOW = GLOBAL_OBJ; +var DEFAULT_MAX_STRING_LENGTH = 80; +/** +* Given a child DOM element, returns a query-selector statement describing that +* and its ancestors +* e.g. [HTMLElement] => body > div > input#foo.btn[name=baz] +* @returns generated DOM path +*/ +function htmlTreeAsString(elem, options = {}) { + if (!elem) return ""; + try { + let currentElem = elem; + const MAX_TRAVERSE_HEIGHT = 5; + const out = []; + let height = 0; + let len = 0; + const separator = " > "; + const sepLength = 3; + let nextStr; + const keyAttrs = Array.isArray(options) ? options : options.keyAttrs; + const maxStringLength = !Array.isArray(options) && options.maxStringLength || DEFAULT_MAX_STRING_LENGTH; + while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) { + nextStr = _htmlElementAsString(currentElem, keyAttrs); + if (nextStr === "html" || height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength) break; + out.push(nextStr); + len += nextStr.length; + currentElem = currentElem.parentNode; + } + return out.reverse().join(separator); + } catch { + return ""; + } +} +/** +* Returns a simple, query-selector representation of a DOM element +* e.g. [HTMLElement] => input#foo.btn[name=baz] +* @returns generated DOM path +*/ +function _htmlElementAsString(el, keyAttrs) { + const elem = el; + const out = []; + if (!elem?.tagName) return ""; + if (WINDOW.HTMLElement) { + if (elem instanceof HTMLElement && elem.dataset) { + if (elem.dataset["sentryComponent"]) return elem.dataset["sentryComponent"]; + if (elem.dataset["sentryElement"]) return elem.dataset["sentryElement"]; + } + } + out.push(elem.tagName.toLowerCase()); + const keyAttrPairs = keyAttrs?.length ? keyAttrs.filter((keyAttr) => elem.getAttribute(keyAttr)).map((keyAttr) => [keyAttr, elem.getAttribute(keyAttr)]) : null; + if (keyAttrPairs?.length) keyAttrPairs.forEach((keyAttrPair) => { + out.push(`[${keyAttrPair[0]}="${keyAttrPair[1]}"]`); + }); + else { + if (elem.id) out.push(`#${elem.id}`); + const className = elem.className; + if (className && isString(className)) { + const classes = className.split(/\s+/); + for (const c of classes) out.push(`.${c}`); + } + } + for (const k of [ + "aria-label", + "type", + "name", + "title", + "alt" + ]) { + const attr = elem.getAttribute(k); + if (attr) out.push(`[${k}="${attr}"]`); + } + return out.join(""); +} +/** +* A safe form of location.href +*/ +function getLocationHref() { + try { + return WINDOW.document.location.href; + } catch { + return ""; + } +} +/** +* Given a DOM element, traverses up the tree until it finds the first ancestor node +* that has the `data-sentry-component` or `data-sentry-element` attribute with `data-sentry-component` taking +* precedence. This attribute is added at build-time by projects that have the component name annotation plugin installed. +* +* @returns a string representation of the component for the provided DOM element, or `null` if not found +*/ +function getComponentName(elem) { + if (!WINDOW.HTMLElement) return null; + let currentElem = elem; + const MAX_TRAVERSE_HEIGHT = 5; + for (let i = 0; i < MAX_TRAVERSE_HEIGHT; i++) { + if (!currentElem) return null; + if (currentElem instanceof HTMLElement) { + if (currentElem.dataset["sentryComponent"]) return currentElem.dataset["sentryComponent"]; + if (currentElem.dataset["sentryElement"]) return currentElem.dataset["sentryElement"]; + } + currentElem = currentElem.parentNode; + } + return null; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/string.js +/** +* Truncates given string to the maximum characters count +* +* @param str An object that contains serializable values +* @param max Maximum number of characters in truncated string (0 = unlimited) +* @returns string Encoded +*/ +function truncate(str, max = 0) { + if (typeof str !== "string" || max === 0) return str; + return str.length <= max ? str : `${str.slice(0, max)}...`; +} +/** +* Join values in array +* @param input array of values to be joined together +* @param delimiter string to be placed in-between values +* @returns Joined values +*/ +function safeJoin(input, delimiter) { + if (!Array.isArray(input)) return ""; + const output = []; + for (let i = 0; i < input.length; i++) { + const value = input[i]; + try { + if (isVueViewModel(value)) output.push("[VueViewModel]"); + else output.push(String(value)); + } catch { + output.push("[value cannot be serialized]"); + } + } + return output.join(delimiter); +} +/** +* Checks if the given value matches a regex or string +* +* @param value The string to test +* @param pattern Either a regex or a string against which `value` will be matched +* @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match +* `pattern` if it contains `pattern`. Only applies to string-type patterns. +*/ +function isMatchingPattern(value, pattern, requireExactStringMatch = false) { + if (!isString(value)) return false; + if (isRegExp(pattern)) return pattern.test(value); + if (isString(pattern)) return requireExactStringMatch ? value === pattern : value.includes(pattern); + return false; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/object.js +/** +* Replace a method in an object with a wrapped version of itself. +* +* If the method on the passed object is not a function, the wrapper will not be applied. +* +* @param source An object that contains a method to be wrapped. +* @param name The name of the method to be wrapped. +* @param replacementFactory A higher-order function that takes the original version of the given method and returns a +* wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to +* preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, )` or `origMethod.apply(this, [])` (rather than being called directly), again to preserve `this`. +* @returns void +*/ +function fill(source, name, replacementFactory) { + if (!(name in source)) return; + const original = source[name]; + if (typeof original !== "function") return; + const wrapped = replacementFactory(original); + if (typeof wrapped === "function") markFunctionWrapped(wrapped, original); + try { + source[name] = wrapped; + } catch { + DEBUG_BUILD && debug.log(`Failed to replace method "${name}" in object`, source); + } +} +/** +* Defines a non-enumerable property on the given object. +* +* @param obj The object on which to set the property +* @param name The name of the property to be set +* @param value The value to which to set the property +*/ +function addNonEnumerableProperty(obj, name, value) { + try { + Object.defineProperty(obj, name, { + value, + writable: true, + configurable: true + }); + } catch { + DEBUG_BUILD && debug.log(`Failed to add non-enumerable property "${name}" to object`, obj); + } +} +/** +* Remembers the original function on the wrapped function and +* patches up the prototype. +* +* @param wrapped the wrapper function +* @param original the original function that gets wrapped +*/ +function markFunctionWrapped(wrapped, original) { + try { + wrapped.prototype = original.prototype = original.prototype || {}; + addNonEnumerableProperty(wrapped, "__sentry_original__", original); + } catch {} +} +/** +* This extracts the original function if available. See +* `markFunctionWrapped` for more information. +* +* @param func the function to unwrap +* @returns the unwrapped version of the function if available. +*/ +function getOriginalFunction(func) { + return func.__sentry_original__; +} +/** +* Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their +* non-enumerable properties attached. +* +* @param value Initial source that we have to transform in order for it to be usable by the serializer +* @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor +* an Error. +*/ +function convertToPlainObject(value) { + if (isError(value)) return { + message: value.message, + name: value.name, + stack: value.stack, + ...getOwnProperties(value) + }; + else if (isEvent(value)) { + const newObj = { + type: value.type, + target: serializeEventTarget(value.target), + currentTarget: serializeEventTarget(value.currentTarget), + ...getOwnProperties(value) + }; + if (typeof CustomEvent !== "undefined" && isInstanceOf(value, CustomEvent)) newObj.detail = value.detail; + return newObj; + } else return value; +} +/** Creates a string representation of the target of an `Event` object */ +function serializeEventTarget(target) { + try { + return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target); + } catch { + return ""; + } +} +/** Filters out all but an object's own properties */ +function getOwnProperties(obj) { + if (typeof obj === "object" && obj !== null) { + const extractedProps = {}; + for (const property in obj) if (Object.prototype.hasOwnProperty.call(obj, property)) extractedProps[property] = obj[property]; + return extractedProps; + } else return {}; +} +/** +* Given any captured exception, extract its keys and create a sorted +* and truncated list that will be used inside the event message. +* eg. `Non-error exception captured with keys: foo, bar, baz` +*/ +function extractExceptionKeysForMessage(exception, maxLength = 40) { + const keys = Object.keys(convertToPlainObject(exception)); + keys.sort(); + const firstKey = keys[0]; + if (!firstKey) return "[object has no keys]"; + if (firstKey.length >= maxLength) return truncate(firstKey, maxLength); + for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) { + const serialized = keys.slice(0, includedKeys).join(", "); + if (serialized.length > maxLength) continue; + if (includedKeys === keys.length) return serialized; + return truncate(serialized, maxLength); + } + return ""; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/misc.js +function getCrypto() { + const gbl = GLOBAL_OBJ; + return gbl.crypto || gbl.msCrypto; +} +var emptyUuid; +function getRandomByte() { + return Math.random() * 16; +} +/** +* UUID4 generator +* @param crypto Object that provides the crypto API. +* @returns string Generated UUID4. +*/ +function uuid4(crypto = getCrypto()) { + try { + if (crypto?.randomUUID) return crypto.randomUUID().replace(/-/g, ""); + } catch {} + if (!emptyUuid) emptyUuid = "10000000100040008000100000000000"; + return emptyUuid.replace(/[018]/g, (c) => (c ^ (getRandomByte() & 15) >> c / 4).toString(16)); +} +function getFirstException(event) { + return event.exception?.values?.[0]; +} +/** +* Extracts either message or type+value from an event that can be used for user-facing logs +* @returns event's description +*/ +function getEventDescription(event) { + const { message, event_id: eventId } = event; + if (message) return message; + const firstException = getFirstException(event); + if (firstException) { + if (firstException.type && firstException.value) return `${firstException.type}: ${firstException.value}`; + return firstException.type || firstException.value || eventId || ""; + } + return eventId || ""; +} +/** +* Adds exception values, type and value to an synthetic Exception. +* @param event The event to modify. +* @param value Value of the exception. +* @param type Type of the exception. +* @hidden +*/ +function addExceptionTypeValue(event, value, type) { + const exception = event.exception = event.exception || {}; + const values = exception.values = exception.values || []; + const firstException = values[0] = values[0] || {}; + if (!firstException.value) firstException.value = value || ""; + if (!firstException.type) firstException.type = type || "Error"; +} +/** +* Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed. +* +* @param event The event to modify. +* @param newMechanism Mechanism data to add to the event. +* @hidden +*/ +function addExceptionMechanism(event, newMechanism) { + const firstException = getFirstException(event); + if (!firstException) return; + const defaultMechanism = { + type: "generic", + handled: true + }; + const currentMechanism = firstException.mechanism; + firstException.mechanism = { + ...defaultMechanism, + ...currentMechanism, + ...newMechanism + }; + if (newMechanism && "data" in newMechanism) { + const mergedData = { + ...currentMechanism?.data, + ...newMechanism.data + }; + firstException.mechanism.data = mergedData; + } +} +/** +* Checks whether or not we've already captured the given exception (note: not an identical exception - the very object +* in question), and marks it captured if not. +* +* This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and +* record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so +* that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because +* the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not +* caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This +* function helps us ensure that even if we encounter the same error more than once, we only record it the first time we +* see it. +* +* Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on +* them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent +* object wrapper forms so that this check will always work. However, because we need to flag the exact object which +* will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification +* must be done before the exception captured. +* +* @param A thrown exception to check or flag as having been seen +* @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen) +*/ +function checkOrSetAlreadyCaught(exception) { + if (isAlreadyCaptured(exception)) return true; + try { + addNonEnumerableProperty(exception, "__sentry_captured__", true); + } catch {} + return false; +} +function isAlreadyCaptured(exception) { + try { + return exception.__sentry_captured__; + } catch {} +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/time.js +var ONE_SECOND_IN_MS = 1e3; +/** +* A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance} +* for accessing a high-resolution monotonic clock. +*/ +/** +* Returns a timestamp in seconds since the UNIX epoch using the Date API. +*/ +function dateTimestampInSeconds() { + return Date.now() / ONE_SECOND_IN_MS; +} +/** +* Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not +* support the API. +* +* Wrapping the native API works around differences in behavior from different browsers. +*/ +function createUnixTimestampInSecondsFunc() { + const { performance } = GLOBAL_OBJ; + if (!performance?.now || !performance.timeOrigin) return dateTimestampInSeconds; + const timeOrigin = performance.timeOrigin; + return () => { + return (timeOrigin + performance.now()) / ONE_SECOND_IN_MS; + }; +} +var _cachedTimestampInSeconds; +/** +* Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the +* availability of the Performance API. +* +* BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is +* asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The +* skew can grow to arbitrary amounts like days, weeks or months. +* See https://github.com/getsentry/sentry-javascript/issues/2590. +*/ +function timestampInSeconds() { + return (_cachedTimestampInSeconds ?? (_cachedTimestampInSeconds = createUnixTimestampInSecondsFunc()))(); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/session.js +/** +* Updates a session object with the properties passed in the context. +* +* Note that this function mutates the passed object and returns void. +* (Had to do this instead of returning a new and updated session because closing and sending a session +* makes an update to the session after it was passed to the sending logic. +* @see Client.captureSession ) +* +* @param session the `Session` to update +* @param context the `SessionContext` holding the properties that should be updated in @param session +*/ +function updateSession(session, context = {}) { + if (context.user) { + if (!session.ipAddress && context.user.ip_address) session.ipAddress = context.user.ip_address; + if (!session.did && !context.did) session.did = context.user.id || context.user.email || context.user.username; + } + session.timestamp = context.timestamp || timestampInSeconds(); + if (context.abnormal_mechanism) session.abnormal_mechanism = context.abnormal_mechanism; + if (context.ignoreDuration) session.ignoreDuration = context.ignoreDuration; + if (context.sid) session.sid = context.sid.length === 32 ? context.sid : uuid4(); + if (context.init !== void 0) session.init = context.init; + if (!session.did && context.did) session.did = `${context.did}`; + if (typeof context.started === "number") session.started = context.started; + if (session.ignoreDuration) session.duration = void 0; + else if (typeof context.duration === "number") session.duration = context.duration; + else { + const duration = session.timestamp - session.started; + session.duration = duration >= 0 ? duration : 0; + } + if (context.release) session.release = context.release; + if (context.environment) session.environment = context.environment; + if (!session.ipAddress && context.ipAddress) session.ipAddress = context.ipAddress; + if (!session.userAgent && context.userAgent) session.userAgent = context.userAgent; + if (typeof context.errors === "number") session.errors = context.errors; + if (context.status) session.status = context.status; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/merge.js +/** +* Shallow merge two objects. +* Does not mutate the passed in objects. +* Undefined/empty values in the merge object will overwrite existing values. +* +* By default, this merges 2 levels deep. +*/ +function merge(initialObj, mergeObj, levels = 2) { + if (!mergeObj || typeof mergeObj !== "object" || levels <= 0) return mergeObj; + if (initialObj && Object.keys(mergeObj).length === 0) return initialObj; + const output = { ...initialObj }; + for (const key in mergeObj) if (Object.prototype.hasOwnProperty.call(mergeObj, key)) output[key] = merge(output[key], mergeObj[key], levels - 1); + return output; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/propagationContext.js +/** +* Generate a random, valid trace ID. +*/ +function generateTraceId() { + return uuid4(); +} +/** +* Generate a random, valid span ID. +*/ +function generateSpanId() { + return uuid4().substring(16); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/spanOnScope.js +var SCOPE_SPAN_FIELD = "_sentrySpan"; +/** +* Set the active span for a given scope. +* NOTE: This should NOT be used directly, but is only used internally by the trace methods. +*/ +function _setSpanForScope(scope, span) { + if (span) addNonEnumerableProperty(scope, SCOPE_SPAN_FIELD, span); + else delete scope[SCOPE_SPAN_FIELD]; +} +/** +* Get the active span for a given scope. +* NOTE: This should NOT be used directly, but is only used internally by the trace methods. +*/ +function _getSpanForScope(scope) { + return scope[SCOPE_SPAN_FIELD]; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/scope.js +/** +* Default value for maximum number of breadcrumbs added to an event. +*/ +var DEFAULT_MAX_BREADCRUMBS = 100; +/** +* A context to be used for capturing an event. +* This can either be a Scope, or a partial ScopeContext, +* or a callback that receives the current scope and returns a new scope to use. +*/ +/** +* Holds additional event information. +*/ +var Scope = class Scope { + /** Flag if notifying is happening. */ + /** Callback for client to receive scope changes. */ + /** Callback list that will be called during event processing. */ + /** Array of breadcrumbs. */ + /** User */ + /** Tags */ + /** Extra */ + /** Contexts */ + /** Attachments */ + /** Propagation Context for distributed tracing */ + /** + * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get + * sent to Sentry + */ + /** Fingerprint */ + /** Severity */ + /** + * Transaction Name + * + * IMPORTANT: The transaction name on the scope has nothing to do with root spans/transaction objects. + * It's purpose is to assign a transaction to the scope that's added to non-transaction events. + */ + /** Session */ + /** The client on this scope */ + /** Contains the last event id of a captured event. */ + constructor() { + this._notifyingListeners = false; + this._scopeListeners = []; + this._eventProcessors = []; + this._breadcrumbs = []; + this._attachments = []; + this._user = {}; + this._tags = {}; + this._extra = {}; + this._contexts = {}; + this._sdkProcessingMetadata = {}; + this._propagationContext = { + traceId: generateTraceId(), + sampleRand: Math.random() + }; + } + /** + * Clone all data from this scope into a new scope. + */ + clone() { + const newScope = new Scope(); + newScope._breadcrumbs = [...this._breadcrumbs]; + newScope._tags = { ...this._tags }; + newScope._extra = { ...this._extra }; + newScope._contexts = { ...this._contexts }; + if (this._contexts.flags) newScope._contexts.flags = { values: [...this._contexts.flags.values] }; + newScope._user = this._user; + newScope._level = this._level; + newScope._session = this._session; + newScope._transactionName = this._transactionName; + newScope._fingerprint = this._fingerprint; + newScope._eventProcessors = [...this._eventProcessors]; + newScope._attachments = [...this._attachments]; + newScope._sdkProcessingMetadata = { ...this._sdkProcessingMetadata }; + newScope._propagationContext = { ...this._propagationContext }; + newScope._client = this._client; + newScope._lastEventId = this._lastEventId; + _setSpanForScope(newScope, _getSpanForScope(this)); + return newScope; + } + /** + * Update the client assigned to this scope. + * Note that not every scope will have a client assigned - isolation scopes & the global scope will generally not have a client, + * as well as manually created scopes. + */ + setClient(client) { + this._client = client; + } + /** + * Set the ID of the last captured error event. + * This is generally only captured on the isolation scope. + */ + setLastEventId(lastEventId) { + this._lastEventId = lastEventId; + } + /** + * Get the client assigned to this scope. + */ + getClient() { + return this._client; + } + /** + * Get the ID of the last captured error event. + * This is generally only available on the isolation scope. + */ + lastEventId() { + return this._lastEventId; + } + /** + * @inheritDoc + */ + addScopeListener(callback) { + this._scopeListeners.push(callback); + } + /** + * Add an event processor that will be called before an event is sent. + */ + addEventProcessor(callback) { + this._eventProcessors.push(callback); + return this; + } + /** + * Set the user for this scope. + * Set to `null` to unset the user. + */ + setUser(user) { + this._user = user || { + email: void 0, + id: void 0, + ip_address: void 0, + username: void 0 + }; + if (this._session) updateSession(this._session, { user }); + this._notifyScopeListeners(); + return this; + } + /** + * Get the user from this scope. + */ + getUser() { + return this._user; + } + /** + * Set an object that will be merged into existing tags on the scope, + * and will be sent as tags data with the event. + */ + setTags(tags) { + this._tags = { + ...this._tags, + ...tags + }; + this._notifyScopeListeners(); + return this; + } + /** + * Set a single tag that will be sent as tags data with the event. + */ + setTag(key, value) { + this._tags = { + ...this._tags, + [key]: value + }; + this._notifyScopeListeners(); + return this; + } + /** + * Set an object that will be merged into existing extra on the scope, + * and will be sent as extra data with the event. + */ + setExtras(extras) { + this._extra = { + ...this._extra, + ...extras + }; + this._notifyScopeListeners(); + return this; + } + /** + * Set a single key:value extra entry that will be sent as extra data with the event. + */ + setExtra(key, extra) { + this._extra = { + ...this._extra, + [key]: extra + }; + this._notifyScopeListeners(); + return this; + } + /** + * Sets the fingerprint on the scope to send with the events. + * @param {string[]} fingerprint Fingerprint to group events in Sentry. + */ + setFingerprint(fingerprint) { + this._fingerprint = fingerprint; + this._notifyScopeListeners(); + return this; + } + /** + * Sets the level on the scope for future events. + */ + setLevel(level) { + this._level = level; + this._notifyScopeListeners(); + return this; + } + /** + * Sets the transaction name on the scope so that the name of e.g. taken server route or + * the page location is attached to future events. + * + * IMPORTANT: Calling this function does NOT change the name of the currently active + * root span. If you want to change the name of the active root span, use + * `Sentry.updateSpanName(rootSpan, 'new name')` instead. + * + * By default, the SDK updates the scope's transaction name automatically on sensible + * occasions, such as a page navigation or when handling a new request on the server. + */ + setTransactionName(name) { + this._transactionName = name; + this._notifyScopeListeners(); + return this; + } + /** + * Sets context data with the given name. + * Data passed as context will be normalized. You can also pass `null` to unset the context. + * Note that context data will not be merged - calling `setContext` will overwrite an existing context with the same key. + */ + setContext(key, context) { + if (context === null) delete this._contexts[key]; + else this._contexts[key] = context; + this._notifyScopeListeners(); + return this; + } + /** + * Set the session for the scope. + */ + setSession(session) { + if (!session) delete this._session; + else this._session = session; + this._notifyScopeListeners(); + return this; + } + /** + * Get the session from the scope. + */ + getSession() { + return this._session; + } + /** + * Updates the scope with provided data. Can work in three variations: + * - plain object containing updatable attributes + * - Scope instance that'll extract the attributes from + * - callback function that'll receive the current scope as an argument and allow for modifications + */ + update(captureContext) { + if (!captureContext) return this; + const scopeToMerge = typeof captureContext === "function" ? captureContext(this) : captureContext; + const { tags, extra, user, contexts, level, fingerprint = [], propagationContext } = (scopeToMerge instanceof Scope ? scopeToMerge.getScopeData() : isPlainObject(scopeToMerge) ? captureContext : void 0) || {}; + this._tags = { + ...this._tags, + ...tags + }; + this._extra = { + ...this._extra, + ...extra + }; + this._contexts = { + ...this._contexts, + ...contexts + }; + if (user && Object.keys(user).length) this._user = user; + if (level) this._level = level; + if (fingerprint.length) this._fingerprint = fingerprint; + if (propagationContext) this._propagationContext = propagationContext; + return this; + } + /** + * Clears the current scope and resets its properties. + * Note: The client will not be cleared. + */ + clear() { + this._breadcrumbs = []; + this._tags = {}; + this._extra = {}; + this._user = {}; + this._contexts = {}; + this._level = void 0; + this._transactionName = void 0; + this._fingerprint = void 0; + this._session = void 0; + _setSpanForScope(this, void 0); + this._attachments = []; + this.setPropagationContext({ + traceId: generateTraceId(), + sampleRand: Math.random() + }); + this._notifyScopeListeners(); + return this; + } + /** + * Adds a breadcrumb to the scope. + * By default, the last 100 breadcrumbs are kept. + */ + addBreadcrumb(breadcrumb, maxBreadcrumbs) { + const maxCrumbs = typeof maxBreadcrumbs === "number" ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS; + if (maxCrumbs <= 0) return this; + const mergedBreadcrumb = { + timestamp: dateTimestampInSeconds(), + ...breadcrumb, + message: breadcrumb.message ? truncate(breadcrumb.message, 2048) : breadcrumb.message + }; + this._breadcrumbs.push(mergedBreadcrumb); + if (this._breadcrumbs.length > maxCrumbs) { + this._breadcrumbs = this._breadcrumbs.slice(-maxCrumbs); + this._client?.recordDroppedEvent("buffer_overflow", "log_item"); + } + this._notifyScopeListeners(); + return this; + } + /** + * Get the last breadcrumb of the scope. + */ + getLastBreadcrumb() { + return this._breadcrumbs[this._breadcrumbs.length - 1]; + } + /** + * Clear all breadcrumbs from the scope. + */ + clearBreadcrumbs() { + this._breadcrumbs = []; + this._notifyScopeListeners(); + return this; + } + /** + * Add an attachment to the scope. + */ + addAttachment(attachment) { + this._attachments.push(attachment); + return this; + } + /** + * Clear all attachments from the scope. + */ + clearAttachments() { + this._attachments = []; + return this; + } + /** + * Get the data of this scope, which should be applied to an event during processing. + */ + getScopeData() { + return { + breadcrumbs: this._breadcrumbs, + attachments: this._attachments, + contexts: this._contexts, + tags: this._tags, + extra: this._extra, + user: this._user, + level: this._level, + fingerprint: this._fingerprint || [], + eventProcessors: this._eventProcessors, + propagationContext: this._propagationContext, + sdkProcessingMetadata: this._sdkProcessingMetadata, + transactionName: this._transactionName, + span: _getSpanForScope(this) + }; + } + /** + * Add data which will be accessible during event processing but won't get sent to Sentry. + */ + setSDKProcessingMetadata(newData) { + this._sdkProcessingMetadata = merge(this._sdkProcessingMetadata, newData, 2); + return this; + } + /** + * Add propagation context to the scope, used for distributed tracing + */ + setPropagationContext(context) { + this._propagationContext = context; + return this; + } + /** + * Get propagation context from the scope, used for distributed tracing + */ + getPropagationContext() { + return this._propagationContext; + } + /** + * Capture an exception for this scope. + * + * @returns {string} The id of the captured Sentry event. + */ + captureException(exception, hint) { + const eventId = hint?.event_id || uuid4(); + if (!this._client) { + DEBUG_BUILD && debug.warn("No client configured on scope - will not capture exception!"); + return eventId; + } + const syntheticException = /* @__PURE__ */ new Error("Sentry syntheticException"); + this._client.captureException(exception, { + originalException: exception, + syntheticException, + ...hint, + event_id: eventId + }, this); + return eventId; + } + /** + * Capture a message for this scope. + * + * @returns {string} The id of the captured message. + */ + captureMessage(message, level, hint) { + const eventId = hint?.event_id || uuid4(); + if (!this._client) { + DEBUG_BUILD && debug.warn("No client configured on scope - will not capture message!"); + return eventId; + } + const syntheticException = new Error(message); + this._client.captureMessage(message, level, { + originalException: message, + syntheticException, + ...hint, + event_id: eventId + }, this); + return eventId; + } + /** + * Capture a Sentry event for this scope. + * + * @returns {string} The id of the captured event. + */ + captureEvent(event, hint) { + const eventId = hint?.event_id || uuid4(); + if (!this._client) { + DEBUG_BUILD && debug.warn("No client configured on scope - will not capture event!"); + return eventId; + } + this._client.captureEvent(event, { + ...hint, + event_id: eventId + }, this); + return eventId; + } + /** + * This will be called on every set call. + */ + _notifyScopeListeners() { + if (!this._notifyingListeners) { + this._notifyingListeners = true; + this._scopeListeners.forEach((callback) => { + callback(this); + }); + this._notifyingListeners = false; + } + } +}; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/defaultScopes.js +/** Get the default current scope. */ +function getDefaultCurrentScope() { + return getGlobalSingleton("defaultCurrentScope", () => new Scope()); +} +/** Get the default isolation scope. */ +function getDefaultIsolationScope() { + return getGlobalSingleton("defaultIsolationScope", () => new Scope()); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/asyncContext/stackStrategy.js +/** +* This is an object that holds a stack of scopes. +*/ +var AsyncContextStack = class { + constructor(scope, isolationScope) { + let assignedScope; + if (!scope) assignedScope = new Scope(); + else assignedScope = scope; + let assignedIsolationScope; + if (!isolationScope) assignedIsolationScope = new Scope(); + else assignedIsolationScope = isolationScope; + this._stack = [{ scope: assignedScope }]; + this._isolationScope = assignedIsolationScope; + } + /** + * Fork a scope for the stack. + */ + withScope(callback) { + const scope = this._pushScope(); + let maybePromiseResult; + try { + maybePromiseResult = callback(scope); + } catch (e) { + this._popScope(); + throw e; + } + if (isThenable(maybePromiseResult)) return maybePromiseResult.then((res) => { + this._popScope(); + return res; + }, (e) => { + this._popScope(); + throw e; + }); + this._popScope(); + return maybePromiseResult; + } + /** + * Get the client of the stack. + */ + getClient() { + return this.getStackTop().client; + } + /** + * Returns the scope of the top stack. + */ + getScope() { + return this.getStackTop().scope; + } + /** + * Get the isolation scope for the stack. + */ + getIsolationScope() { + return this._isolationScope; + } + /** + * Returns the topmost scope layer in the order domain > local > process. + */ + getStackTop() { + return this._stack[this._stack.length - 1]; + } + /** + * Push a scope to the stack. + */ + _pushScope() { + const scope = this.getScope().clone(); + this._stack.push({ + client: this.getClient(), + scope + }); + return scope; + } + /** + * Pop a scope from the stack. + */ + _popScope() { + if (this._stack.length <= 1) return false; + return !!this._stack.pop(); + } +}; +/** +* Get the global async context stack. +* This will be removed during the v8 cycle and is only here to make migration easier. +*/ +function getAsyncContextStack() { + const sentry = getSentryCarrier(getMainCarrier()); + return sentry.stack = sentry.stack || new AsyncContextStack(getDefaultCurrentScope(), getDefaultIsolationScope()); +} +function withScope$1(callback) { + return getAsyncContextStack().withScope(callback); +} +function withSetScope(scope, callback) { + const stack = getAsyncContextStack(); + return stack.withScope(() => { + stack.getStackTop().scope = scope; + return callback(scope); + }); +} +function withIsolationScope$1(callback) { + return getAsyncContextStack().withScope(() => { + return callback(getAsyncContextStack().getIsolationScope()); + }); +} +/** +* Get the stack-based async context strategy. +*/ +function getStackAsyncContextStrategy() { + return { + withIsolationScope: withIsolationScope$1, + withScope: withScope$1, + withSetScope, + withSetIsolationScope: (_isolationScope, callback) => { + return withIsolationScope$1(callback); + }, + getCurrentScope: () => getAsyncContextStack().getScope(), + getIsolationScope: () => getAsyncContextStack().getIsolationScope() + }; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/asyncContext/index.js +/** +* Get the current async context strategy. +* If none has been setup, the default will be used. +*/ +function getAsyncContextStrategy(carrier) { + const sentry = getSentryCarrier(carrier); + if (sentry.acs) return sentry.acs; + return getStackAsyncContextStrategy(); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/currentScopes.js +/** +* Get the currently active scope. +*/ +function getCurrentScope() { + return getAsyncContextStrategy(getMainCarrier()).getCurrentScope(); +} +/** +* Get the currently active isolation scope. +* The isolation scope is active for the current execution context. +*/ +function getIsolationScope() { + return getAsyncContextStrategy(getMainCarrier()).getIsolationScope(); +} +/** +* Get the global scope. +* This scope is applied to _all_ events. +*/ +function getGlobalScope() { + return getGlobalSingleton("globalScope", () => new Scope()); +} +/** +* Creates a new scope with and executes the given operation within. +* The scope is automatically removed once the operation +* finishes or throws. +*/ +/** +* Either creates a new active scope, or sets the given scope as active scope in the given callback. +*/ +function withScope(...rest) { + const acs = getAsyncContextStrategy(getMainCarrier()); + if (rest.length === 2) { + const [scope, callback] = rest; + if (!scope) return acs.withScope(callback); + return acs.withSetScope(scope, callback); + } + return acs.withScope(rest[0]); +} +/** +* Get the currently active client. +*/ +function getClient() { + return getCurrentScope().getClient(); +} +/** +* Get a trace context for the given scope. +*/ +function getTraceContextFromScope(scope) { + const { traceId, parentSpanId, propagationSpanId } = scope.getPropagationContext(); + const traceContext = { + trace_id: traceId, + span_id: propagationSpanId || generateSpanId() + }; + if (parentSpanId) traceContext.parent_span_id = parentSpanId; + return traceContext; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/semanticAttributes.js +/** +* Use this attribute to represent the source of a span. +* Should be one of: custom, url, route, view, component, task, unknown +* +*/ +var SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = "sentry.source"; +/** +* Attributes that holds the sample rate that was locally applied to a span. +* If this attribute is not defined, it means that the span inherited a sampling decision. +* +* NOTE: Is only defined on root spans. +*/ +var SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = "sentry.sample_rate"; +/** +* Attribute holding the sample rate of the previous trace. +* This is used to sample consistently across subsequent traces in the browser SDK. +* +* Note: Only defined on root spans, if opted into consistent sampling +*/ +var SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = "sentry.previous_trace_sample_rate"; +/** +* Use this attribute to represent the operation of a span. +*/ +var SEMANTIC_ATTRIBUTE_SENTRY_OP = "sentry.op"; +/** +* Use this attribute to represent the origin of a span. +*/ +var SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = "sentry.origin"; +/** +* The id of the profile that this span occurred in. +*/ +var SEMANTIC_ATTRIBUTE_PROFILE_ID = "sentry.profile_id"; +var SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = "sentry.exclusive_time"; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/tracing/spanstatus.js +var SPAN_STATUS_UNSET = 0; +var SPAN_STATUS_OK = 1; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/tracing/utils.js +var SCOPE_ON_START_SPAN_FIELD = "_sentryScope"; +var ISOLATION_SCOPE_ON_START_SPAN_FIELD = "_sentryIsolationScope"; +/** Try to unwrap a scope from a potential WeakRef wrapper. */ +function unwrapScopeFromWeakRef(scopeRef) { + if (!scopeRef) return; + if (typeof scopeRef === "object" && "deref" in scopeRef && typeof scopeRef.deref === "function") try { + return scopeRef.deref(); + } catch { + return; + } + return scopeRef; +} +/** +* Grabs the scope and isolation scope off a span that were active when the span was started. +* If WeakRef was used and scopes have been garbage collected, returns undefined for those scopes. +*/ +function getCapturedScopesOnSpan(span) { + const spanWithScopes = span; + return { + scope: spanWithScopes[SCOPE_ON_START_SPAN_FIELD], + isolationScope: unwrapScopeFromWeakRef(spanWithScopes[ISOLATION_SCOPE_ON_START_SPAN_FIELD]) + }; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/baggage.js +var SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/; +/** +* Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the "sentry-" prefixed values +* from it. +* +* @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks. +* @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise. +*/ +function baggageHeaderToDynamicSamplingContext(baggageHeader) { + const baggageObject = parseBaggageHeader(baggageHeader); + if (!baggageObject) return; + const dynamicSamplingContext = Object.entries(baggageObject).reduce((acc, [key, value]) => { + if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) { + const nonPrefixedKey = key.slice(7); + acc[nonPrefixedKey] = value; + } + return acc; + }, {}); + if (Object.keys(dynamicSamplingContext).length > 0) return dynamicSamplingContext; + else return; +} +/** +* Take a baggage header and parse it into an object. +*/ +function parseBaggageHeader(baggageHeader) { + if (!baggageHeader || !isString(baggageHeader) && !Array.isArray(baggageHeader)) return; + if (Array.isArray(baggageHeader)) return baggageHeader.reduce((acc, curr) => { + const currBaggageObject = baggageHeaderToObject(curr); + Object.entries(currBaggageObject).forEach(([key, value]) => { + acc[key] = value; + }); + return acc; + }, {}); + return baggageHeaderToObject(baggageHeader); +} +/** +* Will parse a baggage header, which is a simple key-value map, into a flat object. +* +* @param baggageHeader The baggage header to parse. +* @returns a flat object containing all the key-value pairs from `baggageHeader`. +*/ +function baggageHeaderToObject(baggageHeader) { + return baggageHeader.split(",").map((baggageEntry) => { + const eqIdx = baggageEntry.indexOf("="); + if (eqIdx === -1) return []; + return [baggageEntry.slice(0, eqIdx), baggageEntry.slice(eqIdx + 1)].map((keyOrValue) => { + try { + return decodeURIComponent(keyOrValue.trim()); + } catch { + return; + } + }); + }).reduce((acc, [key, value]) => { + if (key && value) acc[key] = value; + return acc; + }, {}); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/dsn.js +/** Regular expression used to extract org ID from a DSN host. */ +var ORG_ID_REGEX = /^o(\d+)\./; +/** Regular expression used to parse a Dsn. */ +var DSN_REGEX = /^(?:(\w+):)\/\/(?:(\w+)(?::(\w+)?)?@)([\w.-]+)(?::(\d+))?\/(.+)/; +function isValidProtocol(protocol) { + return protocol === "http" || protocol === "https"; +} +/** +* Renders the string representation of this Dsn. +* +* By default, this will render the public representation without the password +* component. To get the deprecated private representation, set `withPassword` +* to true. +* +* @param withPassword When set to true, the password will be included. +*/ +function dsnToString(dsn, withPassword = false) { + const { host, path, pass, port, projectId, protocol, publicKey } = dsn; + return `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ""}@${host}${port ? `:${port}` : ""}/${path ? `${path}/` : path}${projectId}`; +} +/** +* Parses a Dsn from a given string. +* +* @param str A Dsn as string +* @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string +*/ +function dsnFromString(str) { + const match = DSN_REGEX.exec(str); + if (!match) { + consoleSandbox(() => { + console.error(`Invalid Sentry Dsn: ${str}`); + }); + return; + } + const [protocol, publicKey, pass = "", host = "", port = "", lastPath = ""] = match.slice(1); + let path = ""; + let projectId = lastPath; + const split = projectId.split("/"); + if (split.length > 1) { + path = split.slice(0, -1).join("/"); + projectId = split.pop(); + } + if (projectId) { + const projectMatch = projectId.match(/^\d+/); + if (projectMatch) projectId = projectMatch[0]; + } + return dsnFromComponents({ + host, + pass, + path, + projectId, + port, + protocol, + publicKey + }); +} +function dsnFromComponents(components) { + return { + protocol: components.protocol, + publicKey: components.publicKey || "", + pass: components.pass || "", + host: components.host, + port: components.port || "", + path: components.path || "", + projectId: components.projectId + }; +} +function validateDsn(dsn) { + if (!DEBUG_BUILD) return true; + const { port, projectId, protocol } = dsn; + if ([ + "protocol", + "publicKey", + "host", + "projectId" + ].find((component) => { + if (!dsn[component]) { + debug.error(`Invalid Sentry Dsn: ${component} missing`); + return true; + } + return false; + })) return false; + if (!projectId.match(/^\d+$/)) { + debug.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`); + return false; + } + if (!isValidProtocol(protocol)) { + debug.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`); + return false; + } + if (port && isNaN(parseInt(port, 10))) { + debug.error(`Invalid Sentry Dsn: Invalid port ${port}`); + return false; + } + return true; +} +/** +* Extract the org ID from a DSN host. +* +* @param host The host from a DSN +* @returns The org ID if found, undefined otherwise +*/ +function extractOrgIdFromDsnHost(host) { + return host.match(ORG_ID_REGEX)?.[1]; +} +/** +* Returns the organization ID of the client. +* +* The organization ID is extracted from the DSN. If the client options include a `orgId`, this will always take precedence. +*/ +function extractOrgIdFromClient(client) { + const options = client.getOptions(); + const { host } = client.getDsn() || {}; + let org_id; + if (options.orgId) org_id = String(options.orgId); + else if (host) org_id = extractOrgIdFromDsnHost(host); + return org_id; +} +/** +* Creates a valid Sentry Dsn object, identifying a Sentry instance and project. +* @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source +*/ +function makeDsn(from) { + const components = typeof from === "string" ? dsnFromString(from) : dsnFromComponents(from); + if (!components || !validateDsn(components)) return; + return components; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/spanUtils.js +var TRACE_FLAG_SAMPLED = 1; +var hasShownSpanDropWarning = false; +/** +* Convert a span to a trace context, which can be sent as the `trace` context in a non-transaction event. +*/ +function spanToTraceContext(span) { + const { spanId, traceId: trace_id, isRemote } = span.spanContext(); + const parent_span_id = isRemote ? spanId : spanToJSON(span).parent_span_id; + const scope = getCapturedScopesOnSpan(span).scope; + return { + parent_span_id, + span_id: isRemote ? scope?.getPropagationContext().propagationSpanId || generateSpanId() : spanId, + trace_id + }; +} +/** +* Converts the span links array to a flattened version to be sent within an envelope. +* +* If the links array is empty, it returns `undefined` so the empty value can be dropped before it's sent. +*/ +function convertSpanLinksForEnvelope(links) { + if (links && links.length > 0) return links.map(({ context: { spanId, traceId, traceFlags,...restContext }, attributes }) => ({ + span_id: spanId, + trace_id: traceId, + sampled: traceFlags === 1, + attributes, + ...restContext + })); + else return; +} +/** +* Convert a span time input into a timestamp in seconds. +*/ +function spanTimeInputToSeconds(input) { + if (typeof input === "number") return ensureTimestampInSeconds(input); + if (Array.isArray(input)) return input[0] + input[1] / 1e9; + if (input instanceof Date) return ensureTimestampInSeconds(input.getTime()); + return timestampInSeconds(); +} +/** +* Converts a timestamp to second, if it was in milliseconds, or keeps it as second. +*/ +function ensureTimestampInSeconds(timestamp) { + return timestamp > 9999999999 ? timestamp / 1e3 : timestamp; +} +/** +* Convert a span to a JSON representation. +*/ +function spanToJSON(span) { + if (spanIsSentrySpan(span)) return span.getSpanJSON(); + const { spanId: span_id, traceId: trace_id } = span.spanContext(); + if (spanIsOpenTelemetrySdkTraceBaseSpan(span)) { + const { attributes, startTime, name, endTime, status, links } = span; + return { + span_id, + trace_id, + data: attributes, + description: name, + parent_span_id: "parentSpanId" in span ? span.parentSpanId : "parentSpanContext" in span ? span.parentSpanContext?.spanId : void 0, + start_timestamp: spanTimeInputToSeconds(startTime), + timestamp: spanTimeInputToSeconds(endTime) || void 0, + status: getStatusMessage(status), + op: attributes[SEMANTIC_ATTRIBUTE_SENTRY_OP], + origin: attributes[SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN], + links: convertSpanLinksForEnvelope(links) + }; + } + return { + span_id, + trace_id, + start_timestamp: 0, + data: {} + }; +} +function spanIsOpenTelemetrySdkTraceBaseSpan(span) { + const castSpan = span; + return !!castSpan.attributes && !!castSpan.startTime && !!castSpan.name && !!castSpan.endTime && !!castSpan.status; +} +/** Exported only for tests. */ +/** +* Sadly, due to circular dependency checks we cannot actually import the Span class here and check for instanceof. +* :( So instead we approximate this by checking if it has the `getSpanJSON` method. +*/ +function spanIsSentrySpan(span) { + return typeof span.getSpanJSON === "function"; +} +/** +* Returns true if a span is sampled. +* In most cases, you should just use `span.isRecording()` instead. +* However, this has a slightly different semantic, as it also returns false if the span is finished. +* So in the case where this distinction is important, use this method. +*/ +function spanIsSampled(span) { + const { traceFlags } = span.spanContext(); + return traceFlags === 1; +} +/** Get the status message to use for a JSON representation of a span. */ +function getStatusMessage(status) { + if (!status || status.code === 0) return; + if (status.code === 1) return "ok"; + return status.message || "unknown_error"; +} +var ROOT_SPAN_FIELD = "_sentryRootSpan"; +/** +* Returns the root span of a given span. +*/ +function getRootSpan(span) { + return span[ROOT_SPAN_FIELD] || span; +} +/** +* Logs a warning once if `beforeSendSpan` is used to drop spans. +*/ +function showSpanDropWarning() { + if (!hasShownSpanDropWarning) { + consoleSandbox(() => { + console.warn("[Sentry] Returning null from `beforeSendSpan` is disallowed. To drop certain spans, configure the respective integrations directly or use `ignoreSpans`."); + }); + hasShownSpanDropWarning = true; + } +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/hasSpansEnabled.js +/** +* Determines if span recording is currently enabled. +* +* Spans are recorded when at least one of `tracesSampleRate` and `tracesSampler` +* is defined in the SDK config. This function does not make any assumption about +* sampling decisions, it only checks if the SDK is configured to record spans. +* +* Important: This function only determines if span recording is enabled. Trace +* continuation and propagation is separately controlled and not covered by this function. +* If this function returns `false`, traces can still be propagated (which is what +* we refer to by "Tracing without Performance") +* @see https://develop.sentry.dev/sdk/telemetry/traces/tracing-without-performance/ +* +* @param maybeOptions An SDK options object to be passed to this function. +* If this option is not provided, the function will use the current client's options. +*/ +function hasSpansEnabled(maybeOptions) { + if (typeof __SENTRY_TRACING__ === "boolean" && !__SENTRY_TRACING__) return false; + const options = maybeOptions || getClient()?.getOptions(); + return !!options && (options.tracesSampleRate != null || !!options.tracesSampler); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/constants.js +var DEFAULT_ENVIRONMENT = "production"; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/tracing/dynamicSamplingContext.js +/** +* If you change this value, also update the terser plugin config to +* avoid minification of the object property! +*/ +var FROZEN_DSC_FIELD = "_frozenDsc"; +/** +* Creates a dynamic sampling context from a client. +* +* Dispatches the `createDsc` lifecycle hook as a side effect. +*/ +function getDynamicSamplingContextFromClient(trace_id, client) { + const options = client.getOptions(); + const { publicKey: public_key } = client.getDsn() || {}; + const dsc = { + environment: options.environment || "production", + release: options.release, + public_key, + trace_id, + org_id: extractOrgIdFromClient(client) + }; + client.emit("createDsc", dsc); + return dsc; +} +/** +* Get the dynamic sampling context for the currently active scopes. +*/ +function getDynamicSamplingContextFromScope(client, scope) { + const propagationContext = scope.getPropagationContext(); + return propagationContext.dsc || getDynamicSamplingContextFromClient(propagationContext.traceId, client); +} +/** +* Creates a dynamic sampling context from a span (and client and scope) +* +* @param span the span from which a few values like the root span name and sample rate are extracted. +* +* @returns a dynamic sampling context +*/ +function getDynamicSamplingContextFromSpan(span) { + const client = getClient(); + if (!client) return {}; + const rootSpan = getRootSpan(span); + const rootSpanJson = spanToJSON(rootSpan); + const rootSpanAttributes = rootSpanJson.data; + const traceState = rootSpan.spanContext().traceState; + const rootSpanSampleRate = traceState?.get("sentry.sample_rate") ?? rootSpanAttributes["sentry.sample_rate"] ?? rootSpanAttributes["sentry.previous_trace_sample_rate"]; + function applyLocalSampleRateToDsc(dsc$1) { + if (typeof rootSpanSampleRate === "number" || typeof rootSpanSampleRate === "string") dsc$1.sample_rate = `${rootSpanSampleRate}`; + return dsc$1; + } + const frozenDsc = rootSpan[FROZEN_DSC_FIELD]; + if (frozenDsc) return applyLocalSampleRateToDsc(frozenDsc); + const traceStateDsc = traceState?.get("sentry.dsc"); + const dscOnTraceState = traceStateDsc && baggageHeaderToDynamicSamplingContext(traceStateDsc); + if (dscOnTraceState) return applyLocalSampleRateToDsc(dscOnTraceState); + const dsc = getDynamicSamplingContextFromClient(span.spanContext().traceId, client); + const source = rootSpanAttributes[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]; + const name = rootSpanJson.description; + if (source !== "url" && name) dsc.transaction = name; + if (hasSpansEnabled()) { + dsc.sampled = String(spanIsSampled(rootSpan)); + dsc.sample_rand = traceState?.get("sentry.sample_rand") ?? getCapturedScopesOnSpan(rootSpan).scope?.getPropagationContext().sampleRand.toString(); + } + applyLocalSampleRateToDsc(dsc); + client.emit("createDsc", dsc, rootSpan); + return dsc; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/normalize.js +/** +* Recursively normalizes the given object. +* +* - Creates a copy to prevent original input mutation +* - Skips non-enumerable properties +* - When stringifying, calls `toJSON` if implemented +* - Removes circular references +* - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format +* - Translates known global objects/classes to a string representations +* - Takes care of `Error` object serialization +* - Optionally limits depth of final output +* - Optionally limits number of properties/elements included in any single object/array +* +* @param input The object to be normalized. +* @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.) +* @param maxProperties The max number of elements or properties to be included in any single array or +* object in the normalized output. +* @returns A normalized version of the object, or `"**non-serializable**"` if any errors are thrown during normalization. +*/ +function normalize(input, depth = 100, maxProperties = Infinity) { + try { + return visit("", input, depth, maxProperties); + } catch (err) { + return { ERROR: `**non-serializable** (${err})` }; + } +} +/** JSDoc */ +function normalizeToSize(object, depth = 3, maxSize = 100 * 1024) { + const normalized = normalize(object, depth); + if (jsonSize(normalized) > maxSize) return normalizeToSize(object, depth - 1, maxSize); + return normalized; +} +/** +* Visits a node to perform normalization on it +* +* @param key The key corresponding to the given node +* @param value The node to be visited +* @param depth Optional number indicating the maximum recursion depth +* @param maxProperties Optional maximum number of properties/elements included in any single object/array +* @param memo Optional Memo class handling decycling +*/ +function visit(key, value, depth = Infinity, maxProperties = Infinity, memo = memoBuilder()) { + const [memoize, unmemoize] = memo; + if (value == null || ["boolean", "string"].includes(typeof value) || typeof value === "number" && Number.isFinite(value)) return value; + const stringified = stringifyValue(key, value); + if (!stringified.startsWith("[object ")) return stringified; + if (value["__sentry_skip_normalization__"]) return value; + const remainingDepth = typeof value["__sentry_override_normalization_depth__"] === "number" ? value["__sentry_override_normalization_depth__"] : depth; + if (remainingDepth === 0) return stringified.replace("object ", ""); + if (memoize(value)) return "[Circular ~]"; + const valueWithToJSON = value; + if (valueWithToJSON && typeof valueWithToJSON.toJSON === "function") try { + return visit("", valueWithToJSON.toJSON(), remainingDepth - 1, maxProperties, memo); + } catch {} + const normalized = Array.isArray(value) ? [] : {}; + let numAdded = 0; + const visitable = convertToPlainObject(value); + for (const visitKey in visitable) { + if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) continue; + if (numAdded >= maxProperties) { + normalized[visitKey] = "[MaxProperties ~]"; + break; + } + const visitValue = visitable[visitKey]; + normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo); + numAdded++; + } + unmemoize(value); + return normalized; +} +/** +* Stringify the given value. Handles various known special values and types. +* +* Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn +* the number 1231 into "[Object Number]", nor on `null`, as it will throw. +* +* @param value The value to stringify +* @returns A stringified representation of the given value +*/ +function stringifyValue(key, value) { + try { + if (key === "domain" && value && typeof value === "object" && value._events) return "[Domain]"; + if (key === "domainEmitter") return "[DomainEmitter]"; + if (typeof global !== "undefined" && value === global) return "[Global]"; + if (typeof window !== "undefined" && value === window) return "[Window]"; + if (typeof document !== "undefined" && value === document) return "[Document]"; + if (isVueViewModel(value)) return "[VueViewModel]"; + if (isSyntheticEvent(value)) return "[SyntheticEvent]"; + if (typeof value === "number" && !Number.isFinite(value)) return `[${value}]`; + if (typeof value === "function") return `[Function: ${getFunctionName(value)}]`; + if (typeof value === "symbol") return `[${String(value)}]`; + if (typeof value === "bigint") return `[BigInt: ${String(value)}]`; + const objName = getConstructorName(value); + if (/^HTML(\w*)Element$/.test(objName)) return `[HTMLElement: ${objName}]`; + return `[object ${objName}]`; + } catch (err) { + return `**non-serializable** (${err})`; + } +} +function getConstructorName(value) { + const prototype = Object.getPrototypeOf(value); + return prototype?.constructor ? prototype.constructor.name : "null prototype"; +} +/** Calculates bytes size of input string */ +function utf8Length(value) { + return ~-encodeURI(value).split(/%..|./).length; +} +/** Calculates bytes size of input object */ +function jsonSize(value) { + return utf8Length(JSON.stringify(value)); +} +/** +* Helper to decycle json objects +*/ +function memoBuilder() { + const inner = /* @__PURE__ */ new WeakSet(); + function memoize(obj) { + if (inner.has(obj)) return true; + inner.add(obj); + return false; + } + function unmemoize(obj) { + inner.delete(obj); + } + return [memoize, unmemoize]; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/syncpromise.js +/** SyncPromise internal states */ +var STATE_PENDING = 0; +var STATE_RESOLVED = 1; +var STATE_REJECTED = 2; +/** +* Creates a resolved sync promise. +* +* @param value the value to resolve the promise with +* @returns the resolved sync promise +*/ +function resolvedSyncPromise(value) { + return new SyncPromise((resolve) => { + resolve(value); + }); +} +/** +* Creates a rejected sync promise. +* +* @param value the value to reject the promise with +* @returns the rejected sync promise +*/ +function rejectedSyncPromise(reason) { + return new SyncPromise((_, reject) => { + reject(reason); + }); +} +/** +* Thenable class that behaves like a Promise and follows it's interface +* but is not async internally +*/ +var SyncPromise = class SyncPromise { + constructor(executor) { + this._state = STATE_PENDING; + this._handlers = []; + this._runExecutor(executor); + } + /** @inheritdoc */ + then(onfulfilled, onrejected) { + return new SyncPromise((resolve, reject) => { + this._handlers.push([ + false, + (result) => { + if (!onfulfilled) resolve(result); + else try { + resolve(onfulfilled(result)); + } catch (e) { + reject(e); + } + }, + (reason) => { + if (!onrejected) reject(reason); + else try { + resolve(onrejected(reason)); + } catch (e) { + reject(e); + } + } + ]); + this._executeHandlers(); + }); + } + /** @inheritdoc */ + catch(onrejected) { + return this.then((val) => val, onrejected); + } + /** @inheritdoc */ + finally(onfinally) { + return new SyncPromise((resolve, reject) => { + let val; + let isRejected; + return this.then((value) => { + isRejected = false; + val = value; + if (onfinally) onfinally(); + }, (reason) => { + isRejected = true; + val = reason; + if (onfinally) onfinally(); + }).then(() => { + if (isRejected) { + reject(val); + return; + } + resolve(val); + }); + }); + } + /** Excute the resolve/reject handlers. */ + _executeHandlers() { + if (this._state === STATE_PENDING) return; + const cachedHandlers = this._handlers.slice(); + this._handlers = []; + cachedHandlers.forEach((handler) => { + if (handler[0]) return; + if (this._state === STATE_RESOLVED) handler[1](this._value); + if (this._state === STATE_REJECTED) handler[2](this._value); + handler[0] = true; + }); + } + /** Run the executor for the SyncPromise. */ + _runExecutor(executor) { + const setResult = (state, value) => { + if (this._state !== STATE_PENDING) return; + if (isThenable(value)) { + value.then(resolve, reject); + return; + } + this._state = state; + this._value = value; + this._executeHandlers(); + }; + const resolve = (value) => { + setResult(STATE_RESOLVED, value); + }; + const reject = (reason) => { + setResult(STATE_REJECTED, reason); + }; + try { + executor(resolve, reject); + } catch (e) { + reject(e); + } + } +}; + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/eventProcessors.js +/** +* Process an array of event processors, returning the processed event (or `null` if the event was dropped). +*/ +function notifyEventProcessors(processors, event, hint, index = 0) { + try { + const result = _notifyEventProcessors(event, hint, processors, index); + return isThenable(result) ? result : resolvedSyncPromise(result); + } catch (error$1) { + return rejectedSyncPromise(error$1); + } +} +function _notifyEventProcessors(event, hint, processors, index) { + const processor = processors[index]; + if (!event || !processor) return event; + const result = processor({ ...event }, hint); + DEBUG_BUILD && result === null && debug.log(`Event processor "${processor.id || "?"}" dropped event`); + if (isThenable(result)) return result.then((final) => _notifyEventProcessors(final, hint, processors, index + 1)); + return _notifyEventProcessors(result, hint, processors, index + 1); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/applyScopeDataToEvent.js +/** +* Applies data from the scope to the event and runs all event processors on it. +*/ +function applyScopeDataToEvent(event, data) { + const { fingerprint, span, breadcrumbs, sdkProcessingMetadata } = data; + applyDataToEvent(event, data); + if (span) applySpanToEvent(event, span); + applyFingerprintToEvent(event, fingerprint); + applyBreadcrumbsToEvent(event, breadcrumbs); + applySdkMetadataToEvent(event, sdkProcessingMetadata); +} +/** Merge data of two scopes together. */ +function mergeScopeData(data, mergeData) { + const { extra, tags, user, contexts, level, sdkProcessingMetadata, breadcrumbs, fingerprint, eventProcessors, attachments, propagationContext, transactionName, span } = mergeData; + mergeAndOverwriteScopeData(data, "extra", extra); + mergeAndOverwriteScopeData(data, "tags", tags); + mergeAndOverwriteScopeData(data, "user", user); + mergeAndOverwriteScopeData(data, "contexts", contexts); + data.sdkProcessingMetadata = merge(data.sdkProcessingMetadata, sdkProcessingMetadata, 2); + if (level) data.level = level; + if (transactionName) data.transactionName = transactionName; + if (span) data.span = span; + if (breadcrumbs.length) data.breadcrumbs = [...data.breadcrumbs, ...breadcrumbs]; + if (fingerprint.length) data.fingerprint = [...data.fingerprint, ...fingerprint]; + if (eventProcessors.length) data.eventProcessors = [...data.eventProcessors, ...eventProcessors]; + if (attachments.length) data.attachments = [...data.attachments, ...attachments]; + data.propagationContext = { + ...data.propagationContext, + ...propagationContext + }; +} +/** +* Merges certain scope data. Undefined values will overwrite any existing values. +* Exported only for tests. +*/ +function mergeAndOverwriteScopeData(data, prop, mergeVal) { + data[prop] = merge(data[prop], mergeVal, 1); +} +function applyDataToEvent(event, data) { + const { extra, tags, user, contexts, level, transactionName } = data; + if (Object.keys(extra).length) event.extra = { + ...extra, + ...event.extra + }; + if (Object.keys(tags).length) event.tags = { + ...tags, + ...event.tags + }; + if (Object.keys(user).length) event.user = { + ...user, + ...event.user + }; + if (Object.keys(contexts).length) event.contexts = { + ...contexts, + ...event.contexts + }; + if (level) event.level = level; + if (transactionName && event.type !== "transaction") event.transaction = transactionName; +} +function applyBreadcrumbsToEvent(event, breadcrumbs) { + const mergedBreadcrumbs = [...event.breadcrumbs || [], ...breadcrumbs]; + event.breadcrumbs = mergedBreadcrumbs.length ? mergedBreadcrumbs : void 0; +} +function applySdkMetadataToEvent(event, sdkProcessingMetadata) { + event.sdkProcessingMetadata = { + ...event.sdkProcessingMetadata, + ...sdkProcessingMetadata + }; +} +function applySpanToEvent(event, span) { + event.contexts = { + trace: spanToTraceContext(span), + ...event.contexts + }; + event.sdkProcessingMetadata = { + dynamicSamplingContext: getDynamicSamplingContextFromSpan(span), + ...event.sdkProcessingMetadata + }; + const transactionName = spanToJSON(getRootSpan(span)).description; + if (transactionName && !event.transaction && event.type === "transaction") event.transaction = transactionName; +} +/** +* Applies fingerprint from the scope to the event if there's one, +* uses message if there's one instead or get rid of empty fingerprint +*/ +function applyFingerprintToEvent(event, fingerprint) { + event.fingerprint = event.fingerprint ? Array.isArray(event.fingerprint) ? event.fingerprint : [event.fingerprint] : []; + if (fingerprint) event.fingerprint = event.fingerprint.concat(fingerprint); + if (!event.fingerprint.length) delete event.fingerprint; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/debug-ids.js +var parsedStackResults; +var lastSentryKeysCount; +var lastNativeKeysCount; +var cachedFilenameDebugIds; +/** +* Returns a map of filenames to debug identifiers. +* Supports both proprietary _sentryDebugIds and native _debugIds (e.g., from Vercel) formats. +*/ +function getFilenameToDebugIdMap(stackParser) { + const sentryDebugIdMap = GLOBAL_OBJ._sentryDebugIds; + const nativeDebugIdMap = GLOBAL_OBJ._debugIds; + if (!sentryDebugIdMap && !nativeDebugIdMap) return {}; + const sentryDebugIdKeys = sentryDebugIdMap ? Object.keys(sentryDebugIdMap) : []; + const nativeDebugIdKeys = nativeDebugIdMap ? Object.keys(nativeDebugIdMap) : []; + if (cachedFilenameDebugIds && sentryDebugIdKeys.length === lastSentryKeysCount && nativeDebugIdKeys.length === lastNativeKeysCount) return cachedFilenameDebugIds; + lastSentryKeysCount = sentryDebugIdKeys.length; + lastNativeKeysCount = nativeDebugIdKeys.length; + cachedFilenameDebugIds = {}; + if (!parsedStackResults) parsedStackResults = {}; + const processDebugIds = (debugIdKeys, debugIdMap) => { + for (const key of debugIdKeys) { + const debugId = debugIdMap[key]; + const result = parsedStackResults?.[key]; + if (result && cachedFilenameDebugIds && debugId) { + cachedFilenameDebugIds[result[0]] = debugId; + if (parsedStackResults) parsedStackResults[key] = [result[0], debugId]; + } else if (debugId) { + const parsedStack = stackParser(key); + for (let i = parsedStack.length - 1; i >= 0; i--) { + const filename = parsedStack[i]?.filename; + if (filename && cachedFilenameDebugIds && parsedStackResults) { + cachedFilenameDebugIds[filename] = debugId; + parsedStackResults[key] = [filename, debugId]; + break; + } + } + } + } + }; + if (sentryDebugIdMap) processDebugIds(sentryDebugIdKeys, sentryDebugIdMap); + if (nativeDebugIdMap) processDebugIds(nativeDebugIdKeys, nativeDebugIdMap); + return cachedFilenameDebugIds; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/prepareEvent.js +/** +* This type makes sure that we get either a CaptureContext, OR an EventHint. +* It does not allow mixing them, which could lead to unexpected outcomes, e.g. this is disallowed: +* { user: { id: '123' }, mechanism: { handled: false } } +*/ +/** +* Adds common information to events. +* +* The information includes release and environment from `options`, +* breadcrumbs and context (extra, tags and user) from the scope. +* +* Information that is already present in the event is never overwritten. For +* nested objects, such as the context, keys are merged. +* +* @param event The original event. +* @param hint May contain additional information about the original exception. +* @param scope A scope containing event metadata. +* @returns A new event with more information. +* @hidden +*/ +function prepareEvent(options, event, hint, scope, client, isolationScope) { + const { normalizeDepth = 3, normalizeMaxBreadth = 1e3 } = options; + const prepared = { + ...event, + event_id: event.event_id || hint.event_id || uuid4(), + timestamp: event.timestamp || dateTimestampInSeconds() + }; + const integrations = hint.integrations || options.integrations.map((i) => i.name); + applyClientOptions(prepared, options); + applyIntegrationsMetadata(prepared, integrations); + if (client) client.emit("applyFrameMetadata", event); + if (event.type === void 0) applyDebugIds(prepared, options.stackParser); + const finalScope = getFinalScope(scope, hint.captureContext); + if (hint.mechanism) addExceptionMechanism(prepared, hint.mechanism); + const clientEventProcessors = client ? client.getEventProcessors() : []; + const data = getGlobalScope().getScopeData(); + if (isolationScope) mergeScopeData(data, isolationScope.getScopeData()); + if (finalScope) mergeScopeData(data, finalScope.getScopeData()); + const attachments = [...hint.attachments || [], ...data.attachments]; + if (attachments.length) hint.attachments = attachments; + applyScopeDataToEvent(prepared, data); + return notifyEventProcessors([...clientEventProcessors, ...data.eventProcessors], prepared, hint).then((evt) => { + if (evt) applyDebugMeta(evt); + if (typeof normalizeDepth === "number" && normalizeDepth > 0) return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth); + return evt; + }); +} +/** +* Enhances event using the client configuration. +* It takes care of all "static" values like environment, release and `dist`, +* as well as truncating overly long values. +* +* Only exported for tests. +* +* @param event event instance to be enhanced +*/ +function applyClientOptions(event, options) { + const { environment, release, dist, maxValueLength = 250 } = options; + event.environment = event.environment || environment || "production"; + if (!event.release && release) event.release = release; + if (!event.dist && dist) event.dist = dist; + const request = event.request; + if (request?.url) request.url = truncate(request.url, maxValueLength); +} +/** +* Puts debug IDs into the stack frames of an error event. +*/ +function applyDebugIds(event, stackParser) { + const filenameDebugIdMap = getFilenameToDebugIdMap(stackParser); + event.exception?.values?.forEach((exception) => { + exception.stacktrace?.frames?.forEach((frame) => { + if (frame.filename) frame.debug_id = filenameDebugIdMap[frame.filename]; + }); + }); +} +/** +* Moves debug IDs from the stack frames of an error event into the debug_meta field. +*/ +function applyDebugMeta(event) { + const filenameDebugIdMap = {}; + event.exception?.values?.forEach((exception) => { + exception.stacktrace?.frames?.forEach((frame) => { + if (frame.debug_id) { + if (frame.abs_path) filenameDebugIdMap[frame.abs_path] = frame.debug_id; + else if (frame.filename) filenameDebugIdMap[frame.filename] = frame.debug_id; + delete frame.debug_id; + } + }); + }); + if (Object.keys(filenameDebugIdMap).length === 0) return; + event.debug_meta = event.debug_meta || {}; + event.debug_meta.images = event.debug_meta.images || []; + const images = event.debug_meta.images; + Object.entries(filenameDebugIdMap).forEach(([filename, debug_id]) => { + images.push({ + type: "sourcemap", + code_file: filename, + debug_id + }); + }); +} +/** +* This function adds all used integrations to the SDK info in the event. +* @param event The event that will be filled with all integrations. +*/ +function applyIntegrationsMetadata(event, integrationNames) { + if (integrationNames.length > 0) { + event.sdk = event.sdk || {}; + event.sdk.integrations = [...event.sdk.integrations || [], ...integrationNames]; + } +} +/** +* Applies `normalize` function on necessary `Event` attributes to make them safe for serialization. +* Normalized keys: +* - `breadcrumbs.data` +* - `user` +* - `contexts` +* - `extra` +* @param event Event +* @returns Normalized event +*/ +function normalizeEvent(event, depth, maxBreadth) { + if (!event) return null; + const normalized = { + ...event, + ...event.breadcrumbs && { breadcrumbs: event.breadcrumbs.map((b) => ({ + ...b, + ...b.data && { data: normalize(b.data, depth, maxBreadth) } + })) }, + ...event.user && { user: normalize(event.user, depth, maxBreadth) }, + ...event.contexts && { contexts: normalize(event.contexts, depth, maxBreadth) }, + ...event.extra && { extra: normalize(event.extra, depth, maxBreadth) } + }; + if (event.contexts?.trace && normalized.contexts) { + normalized.contexts.trace = event.contexts.trace; + if (event.contexts.trace.data) normalized.contexts.trace.data = normalize(event.contexts.trace.data, depth, maxBreadth); + } + if (event.spans) normalized.spans = event.spans.map((span) => { + return { + ...span, + ...span.data && { data: normalize(span.data, depth, maxBreadth) } + }; + }); + if (event.contexts?.flags && normalized.contexts) normalized.contexts.flags = normalize(event.contexts.flags, 3, maxBreadth); + return normalized; +} +function getFinalScope(scope, captureContext) { + if (!captureContext) return scope; + const finalScope = scope ? scope.clone() : new Scope(); + finalScope.update(captureContext); + return finalScope; +} +/** +* Parse either an `EventHint` directly, or convert a `CaptureContext` to an `EventHint`. +* This is used to allow to update method signatures that used to accept a `CaptureContext` but should now accept an `EventHint`. +*/ +function parseEventHintOrCaptureContext(hint) { + if (!hint) return; + if (hintIsScopeOrFunction(hint)) return { captureContext: hint }; + if (hintIsScopeContext(hint)) return { captureContext: hint }; + return hint; +} +function hintIsScopeOrFunction(hint) { + return hint instanceof Scope || typeof hint === "function"; +} +var captureContextKeys = [ + "user", + "level", + "extra", + "contexts", + "tags", + "fingerprint", + "propagationContext" +]; +function hintIsScopeContext(hint) { + return Object.keys(hint).some((key) => captureContextKeys.includes(key)); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/exports.js +/** +* Captures an exception event and sends it to Sentry. +* +* @param exception The exception to capture. +* @param hint Optional additional data to attach to the Sentry event. +* @returns the id of the captured Sentry event. +*/ +function captureException(exception, hint) { + return getCurrentScope().captureException(exception, parseEventHintOrCaptureContext(hint)); +} +/** +* Captures a message event and sends it to Sentry. +* +* @param message The message to send to Sentry. +* @param captureContext Define the level of the message or pass in additional data to attach to the message. +* @returns the id of the captured message. +*/ +function captureMessage(message, captureContext) { + const level = typeof captureContext === "string" ? captureContext : void 0; + const context = typeof captureContext !== "string" ? { captureContext } : void 0; + return getCurrentScope().captureMessage(message, level, context); +} +/** +* Captures a manually created event and sends it to Sentry. +* +* @param event The event to send to Sentry. +* @param hint Optional additional data to attach to the Sentry event. +* @returns the id of the captured event. +*/ +function captureEvent(event, hint) { + return getCurrentScope().captureEvent(event, hint); +} + +//#endregion +export { getFramesFromEvent as $, extractExceptionKeysForMessage as A, isDOMException as B, timestampInSeconds as C, getEventDescription as D, checkOrSetAlreadyCaught as E, safeJoin as F, isParameterizedString as G, isErrorEvent as H, getComponentName as I, isRequest as J, isPlainObject as K, getLocationHref as L, getOriginalFunction as M, markFunctionWrapped as N, uuid4 as O, isMatchingPattern as P, createStackParser as Q, htmlTreeAsString as R, dateTimestampInSeconds as S, addExceptionTypeValue as T, isEvent as U, isError as V, isInstanceOf as W, isThenable as X, isString as Y, UNKNOWN_FUNCTION as Z, getIsolationScope as _, rejectedSyncPromise as a, getGlobalSingleton as at, merge as b, getDynamicSamplingContextFromScope as c, GLOBAL_OBJ as ct, dsnToString as d, pipe as dt, getFunctionName as et, makeDsn as f, getCurrentScope as g, getClient as h, prepareEvent as i, originalConsoleMethods as it, fill as j, addNonEnumerableProperty as k, DEFAULT_ENVIRONMENT as l, DEBUG_BUILD as lt, SEMANTIC_ATTRIBUTE_PROFILE_ID as m, captureException as n, consoleSandbox as nt, resolvedSyncPromise as o, getSentryCarrier as ot, SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME as p, isPrimitive as q, captureMessage as r, debug as rt, normalizeToSize as s, SDK_VERSION as st, captureEvent as t, CONSOLE_LEVELS as tt, showSpanDropWarning as u, global as ut, getTraceContextFromScope as v, addExceptionMechanism as w, updateSession as x, withScope as y, isDOMError as z }; +//# sourceMappingURL=exports.CurVqjr0.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js.map b/web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js.map new file mode 100644 index 00000000..fb029d2f --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/exports.CurVqjr0.js.map @@ -0,0 +1 @@ +{"version":3,"file":"exports.CurVqjr0.js","names":["console","withScope","withIsolationScope","dsc","error"],"sources":["../../../../../../node_modules/@mobily/ts-belt/dist/pipe.mjs","../../../../../../node_modules/vite-plugin-node-polyfills/shims/global/dist/index.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/debug-build.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/worldwide.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/version.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/carrier.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/debug-logger.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/stacktrace.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/is.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/browser.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/string.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/object.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/misc.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/time.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/session.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/merge.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/propagationContext.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/spanOnScope.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/scope.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/defaultScopes.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/asyncContext/stackStrategy.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/asyncContext/index.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/currentScopes.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/semanticAttributes.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/tracing/spanstatus.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/tracing/utils.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/baggage.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/dsn.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/spanUtils.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/hasSpansEnabled.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/constants.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/tracing/dynamicSamplingContext.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/normalize.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/syncpromise.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/eventProcessors.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/applyScopeDataToEvent.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/debug-ids.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/prepareEvent.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/exports.js"],"sourcesContent":["function pipe() {\n let e = arguments[0];\n for (let t = 1, p = arguments.length; t < p; t++) {\n e = arguments[t](e);\n }\n return e;\n}\n\nexport { pipe };\n","const global = globalThis || void 0 || self;\n\nexport { global as default, global };\n//# sourceMappingURL=index.js.map\n","/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nconst DEBUG_BUILD = (typeof __SENTRY_DEBUG__ === 'undefined' || __SENTRY_DEBUG__);\n\nexport { DEBUG_BUILD };\n//# sourceMappingURL=debug-build.js.map\n","/** Internal global with common properties and Sentry extensions */\n\n/** Get's the global object for the current JavaScript runtime */\nconst GLOBAL_OBJ = globalThis ;\n\nexport { GLOBAL_OBJ };\n//# sourceMappingURL=worldwide.js.map\n","// This is a magic string replaced by rollup\n\nconst SDK_VERSION = \"10.22.0\" ;\n\nexport { SDK_VERSION };\n//# sourceMappingURL=version.js.map\n","import { SDK_VERSION } from './utils/version.js';\nimport { GLOBAL_OBJ } from './utils/worldwide.js';\n\n/**\n * An object that contains globally accessible properties and maintains a scope stack.\n * @hidden\n */\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nfunction getMainCarrier() {\n // This ensures a Sentry carrier exists\n getSentryCarrier(GLOBAL_OBJ);\n return GLOBAL_OBJ;\n}\n\n/** Will either get the existing sentry carrier, or create a new one. */\nfunction getSentryCarrier(carrier) {\n const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n\n // For now: First SDK that sets the .version property wins\n __SENTRY__.version = __SENTRY__.version || SDK_VERSION;\n\n // Intentionally populating and returning the version of \"this\" SDK instance\n // rather than what's set in .version so that \"this\" SDK always gets its carrier\n return (__SENTRY__[SDK_VERSION] = __SENTRY__[SDK_VERSION] || {});\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__[]` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nfunction getGlobalSingleton(\n name,\n creator,\n obj = GLOBAL_OBJ,\n) {\n const __SENTRY__ = (obj.__SENTRY__ = obj.__SENTRY__ || {});\n const carrier = (__SENTRY__[SDK_VERSION] = __SENTRY__[SDK_VERSION] || {});\n // Note: We do not want to set `carrier.version` here, as this may be called before any `init` is called, e.g. for the default scopes\n return carrier[name] || (carrier[name] = creator());\n}\n\nexport { getGlobalSingleton, getMainCarrier, getSentryCarrier };\n//# sourceMappingURL=carrier.js.map\n","import { getGlobalSingleton } from '../carrier.js';\nimport { DEBUG_BUILD } from '../debug-build.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nconst CONSOLE_LEVELS = [\n 'debug',\n 'info',\n 'warn',\n 'error',\n 'log',\n 'assert',\n 'trace',\n] ;\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\n/** This may be mutated by the console instrumentation. */\nconst originalConsoleMethods\n\n = {};\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nfunction consoleSandbox(callback) {\n if (!('console' in GLOBAL_OBJ)) {\n return callback();\n }\n\n const console = GLOBAL_OBJ.console;\n const wrappedFuncs = {};\n\n const wrappedLevels = Object.keys(originalConsoleMethods) ;\n\n // Restore all wrapped console methods\n wrappedLevels.forEach(level => {\n const originalConsoleMethod = originalConsoleMethods[level];\n wrappedFuncs[level] = console[level] ;\n console[level] = originalConsoleMethod ;\n });\n\n try {\n return callback();\n } finally {\n // Revert restoration to wrapped state\n wrappedLevels.forEach(level => {\n console[level] = wrappedFuncs[level] ;\n });\n }\n}\n\nfunction enable() {\n _getLoggerSettings().enabled = true;\n}\n\nfunction disable() {\n _getLoggerSettings().enabled = false;\n}\n\nfunction isEnabled() {\n return _getLoggerSettings().enabled;\n}\n\nfunction log(...args) {\n _maybeLog('log', ...args);\n}\n\nfunction warn(...args) {\n _maybeLog('warn', ...args);\n}\n\nfunction error(...args) {\n _maybeLog('error', ...args);\n}\n\nfunction _maybeLog(level, ...args) {\n if (!DEBUG_BUILD) {\n return;\n }\n\n if (isEnabled()) {\n consoleSandbox(() => {\n GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args);\n });\n }\n}\n\nfunction _getLoggerSettings() {\n if (!DEBUG_BUILD) {\n return { enabled: false };\n }\n\n return getGlobalSingleton('loggerSettings', () => ({ enabled: false }));\n}\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n */\nconst debug = {\n /** Enable logging. */\n enable,\n /** Disable logging. */\n disable,\n /** Check if logging is enabled. */\n isEnabled,\n /** Log a message. */\n log,\n /** Log a warning. */\n warn,\n /** Log an error. */\n error,\n} ;\n\nexport { CONSOLE_LEVELS, consoleSandbox, debug, originalConsoleMethods };\n//# sourceMappingURL=debug-logger.js.map\n","const STACKTRACE_FRAME_LIMIT = 50;\nconst UNKNOWN_FUNCTION = '?';\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nfunction createStackParser(...parsers) {\n const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n return (stack, skipFirstLines = 0, framesToPop = 0) => {\n const frames = [];\n const lines = stack.split('\\n');\n\n for (let i = skipFirstLines; i < lines.length; i++) {\n let line = lines[i] ;\n // Truncate lines over 1kb because many of the regular expressions use\n // backtracking which results in run time that increases exponentially\n // with input size. Huge strings can result in hangs/Denial of Service:\n // https://github.com/getsentry/sentry-javascript/issues/2286\n if (line.length > 1024) {\n line = line.slice(0, 1024);\n }\n\n // https://github.com/getsentry/sentry-javascript/issues/5459\n // Remove webpack (error: *) wrappers\n const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n // https://github.com/getsentry/sentry-javascript/issues/7813\n // Skip Error: lines\n if (cleanedLine.match(/\\S*Error: /)) {\n continue;\n }\n\n for (const parser of sortedParsers) {\n const frame = parser(cleanedLine);\n\n if (frame) {\n frames.push(frame);\n break;\n }\n }\n\n if (frames.length >= STACKTRACE_FRAME_LIMIT + framesToPop) {\n break;\n }\n }\n\n return stripSentryFramesAndReverse(frames.slice(framesToPop));\n };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nfunction stackParserFromStackParserOptions(stackParser) {\n if (Array.isArray(stackParser)) {\n return createStackParser(...stackParser);\n }\n return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nfunction stripSentryFramesAndReverse(stack) {\n if (!stack.length) {\n return [];\n }\n\n const localStack = Array.from(stack);\n\n // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n if (/sentryWrapped/.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n }\n\n // Reversing in the middle of the procedure allows us to just pop the values off the stack\n localStack.reverse();\n\n // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n\n // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n // is produced within the scope itself, making it:\n //\n // Sentry.captureException()\n // scope.captureException()\n //\n // instead of just the top `Sentry` call itself.\n // This forces us to possibly strip an additional frame in the exact same was as above.\n if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n }\n }\n\n return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n ...frame,\n filename: frame.filename || getLastStackFrame(localStack).filename,\n function: frame.function || UNKNOWN_FUNCTION,\n }));\n}\n\nfunction getLastStackFrame(arr) {\n return arr[arr.length - 1] || {};\n}\n\nconst defaultFunctionName = '';\n\n/**\n * Safely extract function name from itself\n */\nfunction getFunctionName(fn) {\n try {\n if (!fn || typeof fn !== 'function') {\n return defaultFunctionName;\n }\n return fn.name || defaultFunctionName;\n } catch {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n return defaultFunctionName;\n }\n}\n\n/**\n * Get's stack frames from an event without needing to check for undefined properties.\n */\nfunction getFramesFromEvent(event) {\n const exception = event.exception;\n\n if (exception) {\n const frames = [];\n try {\n // @ts-expect-error Object could be undefined\n exception.values.forEach(value => {\n // @ts-expect-error Value could be undefined\n if (value.stacktrace.frames) {\n // @ts-expect-error Value could be undefined\n frames.push(...value.stacktrace.frames);\n }\n });\n return frames;\n } catch {\n return undefined;\n }\n }\n return undefined;\n}\n\nexport { UNKNOWN_FUNCTION, createStackParser, getFramesFromEvent, getFunctionName, stackParserFromStackParserOptions, stripSentryFramesAndReverse };\n//# sourceMappingURL=stacktrace.js.map\n","// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isError(wat) {\n switch (objectToString.call(wat)) {\n case '[object Error]':\n case '[object Exception]':\n case '[object DOMException]':\n case '[object WebAssembly.Exception]':\n return true;\n default:\n return isInstanceOf(wat, Error);\n }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat, className) {\n return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isErrorEvent(wat) {\n return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMError(wat) {\n return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMException(wat) {\n return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isString(wat) {\n return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given string is parameterized\n * {@link isParameterizedString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isParameterizedString(wat) {\n return (\n typeof wat === 'object' &&\n wat !== null &&\n '__sentry_template_string__' in wat &&\n '__sentry_template_values__' in wat\n );\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPrimitive(wat) {\n return wat === null || isParameterizedString(wat) || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal, or a class instance.\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPlainObject(wat) {\n return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isEvent(wat) {\n return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isElement(wat) {\n return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isRegExp(wat) {\n return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nfunction isThenable(wat) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return Boolean(wat?.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isSyntheticEvent(wat) {\n return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nfunction isInstanceOf(wat, base) {\n try {\n return wat instanceof base;\n } catch {\n return false;\n }\n}\n\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isVueViewModel(wat) {\n // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n return !!(typeof wat === 'object' && wat !== null && ((wat ).__isVue || (wat )._isVue));\n}\n\n/**\n * Checks whether the given parameter is a Standard Web API Request instance.\n *\n * Returns false if Request is not available in the current runtime.\n */\nfunction isRequest(request) {\n return typeof Request !== 'undefined' && isInstanceOf(request, Request);\n}\n\nexport { isDOMError, isDOMException, isElement, isError, isErrorEvent, isEvent, isInstanceOf, isParameterizedString, isPlainObject, isPrimitive, isRegExp, isRequest, isString, isSyntheticEvent, isThenable, isVueViewModel };\n//# sourceMappingURL=is.js.map\n","import { isString } from './is.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nconst WINDOW = GLOBAL_OBJ ;\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction htmlTreeAsString(\n elem,\n options = {},\n) {\n if (!elem) {\n return '';\n }\n\n // try/catch both:\n // - accessing event.target (see getsentry/raven-js#838, #768)\n // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n // - can throw an exception in some circumstances.\n try {\n let currentElem = elem ;\n const MAX_TRAVERSE_HEIGHT = 5;\n const out = [];\n let height = 0;\n let len = 0;\n const separator = ' > ';\n const sepLength = separator.length;\n let nextStr;\n const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n nextStr = _htmlElementAsString(currentElem, keyAttrs);\n // bail out if\n // - nextStr is the 'html' element\n // - the length of the string that would be created exceeds maxStringLength\n // (ignore this limit if we are on the first iteration)\n if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n break;\n }\n\n out.push(nextStr);\n\n len += nextStr.length;\n currentElem = currentElem.parentNode;\n }\n\n return out.reverse().join(separator);\n } catch {\n return '';\n }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el, keyAttrs) {\n const elem = el\n\n;\n\n const out = [];\n\n if (!elem?.tagName) {\n return '';\n }\n\n // @ts-expect-error WINDOW has HTMLElement\n if (WINDOW.HTMLElement) {\n // If using the component name annotation plugin, this value may be available on the DOM node\n if (elem instanceof HTMLElement && elem.dataset) {\n if (elem.dataset['sentryComponent']) {\n return elem.dataset['sentryComponent'];\n }\n if (elem.dataset['sentryElement']) {\n return elem.dataset['sentryElement'];\n }\n }\n }\n\n out.push(elem.tagName.toLowerCase());\n\n // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n const keyAttrPairs = keyAttrs?.length\n ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n : null;\n\n if (keyAttrPairs?.length) {\n keyAttrPairs.forEach(keyAttrPair => {\n out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n });\n } else {\n if (elem.id) {\n out.push(`#${elem.id}`);\n }\n\n const className = elem.className;\n if (className && isString(className)) {\n const classes = className.split(/\\s+/);\n for (const c of classes) {\n out.push(`.${c}`);\n }\n }\n }\n const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n for (const k of allowedAttrs) {\n const attr = elem.getAttribute(k);\n if (attr) {\n out.push(`[${k}=\"${attr}\"]`);\n }\n }\n\n return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nfunction getLocationHref() {\n try {\n return WINDOW.document.location.href;\n } catch {\n return '';\n }\n}\n\n/**\n * Given a DOM element, traverses up the tree until it finds the first ancestor node\n * that has the `data-sentry-component` or `data-sentry-element` attribute with `data-sentry-component` taking\n * precedence. This attribute is added at build-time by projects that have the component name annotation plugin installed.\n *\n * @returns a string representation of the component for the provided DOM element, or `null` if not found\n */\nfunction getComponentName(elem) {\n // @ts-expect-error WINDOW has HTMLElement\n if (!WINDOW.HTMLElement) {\n return null;\n }\n\n let currentElem = elem ;\n const MAX_TRAVERSE_HEIGHT = 5;\n for (let i = 0; i < MAX_TRAVERSE_HEIGHT; i++) {\n if (!currentElem) {\n return null;\n }\n\n if (currentElem instanceof HTMLElement) {\n if (currentElem.dataset['sentryComponent']) {\n return currentElem.dataset['sentryComponent'];\n }\n if (currentElem.dataset['sentryElement']) {\n return currentElem.dataset['sentryElement'];\n }\n }\n\n currentElem = currentElem.parentNode;\n }\n\n return null;\n}\n\nexport { getComponentName, getLocationHref, htmlTreeAsString };\n//# sourceMappingURL=browser.js.map\n","import { isString, isRegExp, isVueViewModel } from './is.js';\n\n/**\n * Truncates given string to the maximum characters count\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string (0 = unlimited)\n * @returns string Encoded\n */\nfunction truncate(str, max = 0) {\n if (typeof str !== 'string' || max === 0) {\n return str;\n }\n return str.length <= max ? str : `${str.slice(0, max)}...`;\n}\n\n/**\n * This is basically just `trim_line` from\n * https://github.com/getsentry/sentry/blob/master/src/sentry/lang/javascript/processor.py#L67\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string\n * @returns string Encoded\n */\nfunction snipLine(line, colno) {\n let newLine = line;\n const lineLength = newLine.length;\n if (lineLength <= 150) {\n return newLine;\n }\n if (colno > lineLength) {\n // eslint-disable-next-line no-param-reassign\n colno = lineLength;\n }\n\n let start = Math.max(colno - 60, 0);\n if (start < 5) {\n start = 0;\n }\n\n let end = Math.min(start + 140, lineLength);\n if (end > lineLength - 5) {\n end = lineLength;\n }\n if (end === lineLength) {\n start = Math.max(end - 140, 0);\n }\n\n newLine = newLine.slice(start, end);\n if (start > 0) {\n newLine = `'{snip} ${newLine}`;\n }\n if (end < lineLength) {\n newLine += ' {snip}';\n }\n\n return newLine;\n}\n\n/**\n * Join values in array\n * @param input array of values to be joined together\n * @param delimiter string to be placed in-between values\n * @returns Joined values\n */\nfunction safeJoin(input, delimiter) {\n if (!Array.isArray(input)) {\n return '';\n }\n\n const output = [];\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < input.length; i++) {\n const value = input[i];\n try {\n // This is a hack to fix a Vue3-specific bug that causes an infinite loop of\n // console warnings. This happens when a Vue template is rendered with\n // an undeclared variable, which we try to stringify, ultimately causing\n // Vue to issue another warning which repeats indefinitely.\n // see: https://github.com/getsentry/sentry-javascript/pull/8981\n if (isVueViewModel(value)) {\n output.push('[VueViewModel]');\n } else {\n output.push(String(value));\n }\n } catch {\n output.push('[value cannot be serialized]');\n }\n }\n\n return output.join(delimiter);\n}\n\n/**\n * Checks if the given value matches a regex or string\n *\n * @param value The string to test\n * @param pattern Either a regex or a string against which `value` will be matched\n * @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match\n * `pattern` if it contains `pattern`. Only applies to string-type patterns.\n */\nfunction isMatchingPattern(\n value,\n pattern,\n requireExactStringMatch = false,\n) {\n if (!isString(value)) {\n return false;\n }\n\n if (isRegExp(pattern)) {\n return pattern.test(value);\n }\n if (isString(pattern)) {\n return requireExactStringMatch ? value === pattern : value.includes(pattern);\n }\n\n return false;\n}\n\n/**\n * Test the given string against an array of strings and regexes. By default, string matching is done on a\n * substring-inclusion basis rather than a strict equality basis\n *\n * @param testString The string to test\n * @param patterns The patterns against which to test the string\n * @param requireExactStringMatch If true, `testString` must match one of the given string patterns exactly in order to\n * count. If false, `testString` will match a string pattern if it contains that pattern.\n * @returns\n */\nfunction stringMatchesSomePattern(\n testString,\n patterns = [],\n requireExactStringMatch = false,\n) {\n return patterns.some(pattern => isMatchingPattern(testString, pattern, requireExactStringMatch));\n}\n\nexport { isMatchingPattern, safeJoin, snipLine, stringMatchesSomePattern, truncate };\n//# sourceMappingURL=string.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { htmlTreeAsString } from './browser.js';\nimport { debug } from './debug-logger.js';\nimport { isError, isEvent, isInstanceOf, isPrimitive, isElement } from './is.js';\nimport { truncate } from './string.js';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * If the method on the passed object is not a function, the wrapper will not be applied.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, )` or `origMethod.apply(this, [])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nfunction fill(source, name, replacementFactory) {\n if (!(name in source)) {\n return;\n }\n\n // explicitly casting to unknown because we don't know the type of the method initially at all\n const original = source[name] ;\n\n if (typeof original !== 'function') {\n return;\n }\n\n const wrapped = replacementFactory(original) ;\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (typeof wrapped === 'function') {\n markFunctionWrapped(wrapped, original);\n }\n\n try {\n source[name] = wrapped;\n } catch {\n DEBUG_BUILD && debug.log(`Failed to replace method \"${name}\" in object`, source);\n }\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nfunction addNonEnumerableProperty(obj, name, value) {\n try {\n Object.defineProperty(obj, name, {\n // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n value: value,\n writable: true,\n configurable: true,\n });\n } catch {\n DEBUG_BUILD && debug.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nfunction markFunctionWrapped(wrapped, original) {\n try {\n const proto = original.prototype || {};\n wrapped.prototype = original.prototype = proto;\n addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n } catch {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available. See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction getOriginalFunction(func) {\n return func.__sentry_original__;\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor\n * an Error.\n */\nfunction convertToPlainObject(value)\n\n {\n if (isError(value)) {\n return {\n message: value.message,\n name: value.name,\n stack: value.stack,\n ...getOwnProperties(value),\n };\n } else if (isEvent(value)) {\n const newObj\n\n = {\n type: value.type,\n target: serializeEventTarget(value.target),\n currentTarget: serializeEventTarget(value.currentTarget),\n ...getOwnProperties(value),\n };\n\n if (typeof CustomEvent !== 'undefined' && isInstanceOf(value, CustomEvent)) {\n newObj.detail = value.detail;\n }\n\n return newObj;\n } else {\n return value;\n }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target) {\n try {\n return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target);\n } catch {\n return '';\n }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj) {\n if (typeof obj === 'object' && obj !== null) {\n const extractedProps = {};\n for (const property in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, property)) {\n extractedProps[property] = (obj )[property];\n }\n }\n return extractedProps;\n } else {\n return {};\n }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nfunction extractExceptionKeysForMessage(exception, maxLength = 40) {\n const keys = Object.keys(convertToPlainObject(exception));\n keys.sort();\n\n const firstKey = keys[0];\n\n if (!firstKey) {\n return '[object has no keys]';\n }\n\n if (firstKey.length >= maxLength) {\n return truncate(firstKey, maxLength);\n }\n\n for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n const serialized = keys.slice(0, includedKeys).join(', ');\n if (serialized.length > maxLength) {\n continue;\n }\n if (includedKeys === keys.length) {\n return serialized;\n }\n return truncate(serialized, maxLength);\n }\n\n return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n *\n * @deprecated This function is no longer used by the SDK and will be removed in a future major version.\n */\nfunction dropUndefinedKeys(inputValue) {\n // This map keeps track of what already visited nodes map to.\n // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n // references as the input object.\n const memoizationMap = new Map();\n\n // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys(inputValue, memoizationMap) {\n // Early return for primitive values\n if (inputValue === null || typeof inputValue !== 'object') {\n return inputValue;\n }\n\n // Check memo map first for all object types\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal ;\n }\n\n // handle arrays\n if (Array.isArray(inputValue)) {\n const returnValue = [];\n // Store mapping to handle circular references\n memoizationMap.set(inputValue, returnValue);\n\n inputValue.forEach(value => {\n returnValue.push(_dropUndefinedKeys(value, memoizationMap));\n });\n\n return returnValue ;\n }\n\n if (isPojo(inputValue)) {\n const returnValue = {};\n // Store mapping to handle circular references\n memoizationMap.set(inputValue, returnValue);\n\n const keys = Object.keys(inputValue);\n\n keys.forEach(key => {\n const val = inputValue[key];\n if (val !== undefined) {\n returnValue[key] = _dropUndefinedKeys(val, memoizationMap);\n }\n });\n\n return returnValue ;\n }\n\n // For other object types, return as is\n return inputValue;\n}\n\nfunction isPojo(input) {\n // Plain objects have Object as constructor or no constructor\n const constructor = (input ).constructor;\n return constructor === Object || constructor === undefined;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nfunction objectify(wat) {\n let objectified;\n switch (true) {\n // this will catch both undefined and null\n case wat == undefined:\n objectified = new String(wat);\n break;\n\n // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n // an object in order to wrap it.\n case typeof wat === 'symbol' || typeof wat === 'bigint':\n objectified = Object(wat);\n break;\n\n // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n case isPrimitive(wat):\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n objectified = new (wat ).constructor(wat);\n break;\n\n // by process of elimination, at this point we know that `wat` must already be an object\n default:\n objectified = wat;\n break;\n }\n return objectified;\n}\n\nexport { addNonEnumerableProperty, convertToPlainObject, dropUndefinedKeys, extractExceptionKeysForMessage, fill, getOriginalFunction, markFunctionWrapped, objectify };\n//# sourceMappingURL=object.js.map\n","import { addNonEnumerableProperty } from './object.js';\nimport { snipLine } from './string.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nfunction getCrypto() {\n const gbl = GLOBAL_OBJ ;\n return gbl.crypto || gbl.msCrypto;\n}\n\nlet emptyUuid;\n\nfunction getRandomByte() {\n return Math.random() * 16;\n}\n\n/**\n * UUID4 generator\n * @param crypto Object that provides the crypto API.\n * @returns string Generated UUID4.\n */\nfunction uuid4(crypto = getCrypto()) {\n try {\n if (crypto?.randomUUID) {\n return crypto.randomUUID().replace(/-/g, '');\n }\n } catch {\n // some runtimes can crash invoking crypto\n // https://github.com/getsentry/sentry-javascript/issues/8935\n }\n\n if (!emptyUuid) {\n // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n emptyUuid = ([1e7] ) + 1e3 + 4e3 + 8e3 + 1e11;\n }\n\n return emptyUuid.replace(/[018]/g, c =>\n // eslint-disable-next-line no-bitwise\n ((c ) ^ ((getRandomByte() & 15) >> ((c ) / 4))).toString(16),\n );\n}\n\nfunction getFirstException(event) {\n return event.exception?.values?.[0];\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nfunction getEventDescription(event) {\n const { message, event_id: eventId } = event;\n if (message) {\n return message;\n }\n\n const firstException = getFirstException(event);\n if (firstException) {\n if (firstException.type && firstException.value) {\n return `${firstException.type}: ${firstException.value}`;\n }\n return firstException.type || firstException.value || eventId || '';\n }\n return eventId || '';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nfunction addExceptionTypeValue(event, value, type) {\n const exception = (event.exception = event.exception || {});\n const values = (exception.values = exception.values || []);\n const firstException = (values[0] = values[0] || {});\n if (!firstException.value) {\n firstException.value = value || '';\n }\n if (!firstException.type) {\n firstException.type = type || 'Error';\n }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nfunction addExceptionMechanism(event, newMechanism) {\n const firstException = getFirstException(event);\n if (!firstException) {\n return;\n }\n\n const defaultMechanism = { type: 'generic', handled: true };\n const currentMechanism = firstException.mechanism;\n firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n if (newMechanism && 'data' in newMechanism) {\n const mergedData = { ...currentMechanism?.data, ...newMechanism.data };\n firstException.mechanism.data = mergedData;\n }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\n\nfunction _parseInt(input) {\n return parseInt(input || '', 10);\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nfunction parseSemver(input) {\n const match = input.match(SEMVER_REGEXP) || [];\n const major = _parseInt(match[1]);\n const minor = _parseInt(match[2]);\n const patch = _parseInt(match[3]);\n return {\n buildmetadata: match[5],\n major: isNaN(major) ? undefined : major,\n minor: isNaN(minor) ? undefined : minor,\n patch: isNaN(patch) ? undefined : patch,\n prerelease: match[4],\n };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nfunction addContextToFrame(lines, frame, linesOfContext = 5) {\n // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n if (frame.lineno === undefined) {\n return;\n }\n\n const maxLines = lines.length;\n const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n frame.pre_context = lines\n .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n .map((line) => snipLine(line, 0));\n\n // We guard here to ensure this is not larger than the existing number of lines\n const lineIndex = Math.min(maxLines - 1, sourceLine);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n frame.context_line = snipLine(lines[lineIndex], frame.colno || 0);\n\n frame.post_context = lines\n .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n .map((line) => snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nfunction checkOrSetAlreadyCaught(exception) {\n if (isAlreadyCaptured(exception)) {\n return true;\n }\n\n try {\n // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n // `ExtraErrorData` integration\n addNonEnumerableProperty(exception , '__sentry_captured__', true);\n } catch {\n // `exception` is a primitive, so we can't mark it seen\n }\n\n return false;\n}\n\nfunction isAlreadyCaptured(exception) {\n try {\n return (exception ).__sentry_captured__;\n } catch {} // eslint-disable-line no-empty\n}\n\nexport { addContextToFrame, addExceptionMechanism, addExceptionTypeValue, checkOrSetAlreadyCaught, getEventDescription, parseSemver, uuid4 };\n//# sourceMappingURL=misc.js.map\n","import { GLOBAL_OBJ } from './worldwide.js';\n\nconst ONE_SECOND_IN_MS = 1000;\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nfunction dateTimestampInSeconds() {\n return Date.now() / ONE_SECOND_IN_MS;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction createUnixTimestampInSecondsFunc() {\n const { performance } = GLOBAL_OBJ ;\n // Some browser and environments don't have a performance or timeOrigin, so we fallback to\n // using Date.now() to compute the starting time.\n if (!performance?.now || !performance.timeOrigin) {\n return dateTimestampInSeconds;\n }\n\n const timeOrigin = performance.timeOrigin;\n\n // performance.now() is a monotonic clock, which means it starts at 0 when the process begins. To get the current\n // wall clock time (actual UNIX timestamp), we need to add the starting time origin and the current time elapsed.\n //\n // TODO: This does not account for the case where the monotonic clock that powers performance.now() drifts from the\n // wall clock time, which causes the returned timestamp to be inaccurate. We should investigate how to detect and\n // correct for this.\n // See: https://github.com/getsentry/sentry-javascript/issues/2590\n // See: https://github.com/mdn/content/issues/4713\n // See: https://dev.to/noamr/when-a-millisecond-is-not-a-millisecond-3h6\n return () => {\n return (timeOrigin + performance.now()) / ONE_SECOND_IN_MS;\n };\n}\n\nlet _cachedTimestampInSeconds;\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nfunction timestampInSeconds() {\n // We store this in a closure so that we don't have to create a new function every time this is called.\n const func = _cachedTimestampInSeconds ?? (_cachedTimestampInSeconds = createUnixTimestampInSecondsFunc());\n return func();\n}\n\n/**\n * Cached result of getBrowserTimeOrigin.\n */\nlet cachedTimeOrigin;\n\n/**\n * Gets the time origin and the mode used to determine it.\n */\nfunction getBrowserTimeOrigin() {\n // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n // data as reliable if they are within a reasonable threshold of the current time.\n\n const { performance } = GLOBAL_OBJ ;\n if (!performance?.now) {\n return [undefined, 'none'];\n }\n\n const threshold = 3600 * 1000;\n const performanceNow = performance.now();\n const dateNow = Date.now();\n\n // if timeOrigin isn't available set delta to threshold so it isn't used\n const timeOriginDelta = performance.timeOrigin\n ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n : threshold;\n const timeOriginIsReliable = timeOriginDelta < threshold;\n\n // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n // Date API.\n // eslint-disable-next-line deprecation/deprecation\n const navigationStart = performance.timing?.navigationStart;\n const hasNavigationStart = typeof navigationStart === 'number';\n // if navigationStart isn't available set delta to threshold so it isn't used\n const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n const navigationStartIsReliable = navigationStartDelta < threshold;\n\n if (timeOriginIsReliable || navigationStartIsReliable) {\n // Use the more reliable time origin\n if (timeOriginDelta <= navigationStartDelta) {\n return [performance.timeOrigin, 'timeOrigin'];\n } else {\n return [navigationStart, 'navigationStart'];\n }\n }\n\n // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n return [dateNow, 'dateNow'];\n}\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nfunction browserPerformanceTimeOrigin() {\n if (!cachedTimeOrigin) {\n cachedTimeOrigin = getBrowserTimeOrigin();\n }\n\n return cachedTimeOrigin[0];\n}\n\nexport { browserPerformanceTimeOrigin, dateTimestampInSeconds, timestampInSeconds };\n//# sourceMappingURL=time.js.map\n","import { uuid4 } from './utils/misc.js';\nimport { timestampInSeconds } from './utils/time.js';\n\n/**\n * Creates a new `Session` object by setting certain default parameters. If optional @param context\n * is passed, the passed properties are applied to the session object.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns a new `Session` object\n */\nfunction makeSession(context) {\n // Both timestamp and started are in seconds since the UNIX epoch.\n const startingTime = timestampInSeconds();\n\n const session = {\n sid: uuid4(),\n init: true,\n timestamp: startingTime,\n started: startingTime,\n duration: 0,\n status: 'ok',\n errors: 0,\n ignoreDuration: false,\n toJSON: () => sessionToJSON(session),\n };\n\n if (context) {\n updateSession(session, context);\n }\n\n return session;\n}\n\n/**\n * Updates a session object with the properties passed in the context.\n *\n * Note that this function mutates the passed object and returns void.\n * (Had to do this instead of returning a new and updated session because closing and sending a session\n * makes an update to the session after it was passed to the sending logic.\n * @see Client.captureSession )\n *\n * @param session the `Session` to update\n * @param context the `SessionContext` holding the properties that should be updated in @param session\n */\n// eslint-disable-next-line complexity\nfunction updateSession(session, context = {}) {\n if (context.user) {\n if (!session.ipAddress && context.user.ip_address) {\n session.ipAddress = context.user.ip_address;\n }\n\n if (!session.did && !context.did) {\n session.did = context.user.id || context.user.email || context.user.username;\n }\n }\n\n session.timestamp = context.timestamp || timestampInSeconds();\n\n if (context.abnormal_mechanism) {\n session.abnormal_mechanism = context.abnormal_mechanism;\n }\n\n if (context.ignoreDuration) {\n session.ignoreDuration = context.ignoreDuration;\n }\n if (context.sid) {\n // Good enough uuid validation. — Kamil\n session.sid = context.sid.length === 32 ? context.sid : uuid4();\n }\n if (context.init !== undefined) {\n session.init = context.init;\n }\n if (!session.did && context.did) {\n session.did = `${context.did}`;\n }\n if (typeof context.started === 'number') {\n session.started = context.started;\n }\n if (session.ignoreDuration) {\n session.duration = undefined;\n } else if (typeof context.duration === 'number') {\n session.duration = context.duration;\n } else {\n const duration = session.timestamp - session.started;\n session.duration = duration >= 0 ? duration : 0;\n }\n if (context.release) {\n session.release = context.release;\n }\n if (context.environment) {\n session.environment = context.environment;\n }\n if (!session.ipAddress && context.ipAddress) {\n session.ipAddress = context.ipAddress;\n }\n if (!session.userAgent && context.userAgent) {\n session.userAgent = context.userAgent;\n }\n if (typeof context.errors === 'number') {\n session.errors = context.errors;\n }\n if (context.status) {\n session.status = context.status;\n }\n}\n\n/**\n * Closes a session by setting its status and updating the session object with it.\n * Internally calls `updateSession` to update the passed session object.\n *\n * Note that this function mutates the passed session (@see updateSession for explanation).\n *\n * @param session the `Session` object to be closed\n * @param status the `SessionStatus` with which the session was closed. If you don't pass a status,\n * this function will keep the previously set status, unless it was `'ok'` in which case\n * it is changed to `'exited'`.\n */\nfunction closeSession(session, status) {\n let context = {};\n if (status) {\n context = { status };\n } else if (session.status === 'ok') {\n context = { status: 'exited' };\n }\n\n updateSession(session, context);\n}\n\n/**\n * Serializes a passed session object to a JSON object with a slightly different structure.\n * This is necessary because the Sentry backend requires a slightly different schema of a session\n * than the one the JS SDKs use internally.\n *\n * @param session the session to be converted\n *\n * @returns a JSON object of the passed session\n */\nfunction sessionToJSON(session) {\n return {\n sid: `${session.sid}`,\n init: session.init,\n // Make sure that sec is converted to ms for date constructor\n started: new Date(session.started * 1000).toISOString(),\n timestamp: new Date(session.timestamp * 1000).toISOString(),\n status: session.status,\n errors: session.errors,\n did: typeof session.did === 'number' || typeof session.did === 'string' ? `${session.did}` : undefined,\n duration: session.duration,\n abnormal_mechanism: session.abnormal_mechanism,\n attrs: {\n release: session.release,\n environment: session.environment,\n ip_address: session.ipAddress,\n user_agent: session.userAgent,\n },\n };\n}\n\nexport { closeSession, makeSession, updateSession };\n//# sourceMappingURL=session.js.map\n","/**\n * Shallow merge two objects.\n * Does not mutate the passed in objects.\n * Undefined/empty values in the merge object will overwrite existing values.\n *\n * By default, this merges 2 levels deep.\n */\nfunction merge(initialObj, mergeObj, levels = 2) {\n // If the merge value is not an object, or we have no merge levels left,\n // we just set the value to the merge value\n if (!mergeObj || typeof mergeObj !== 'object' || levels <= 0) {\n return mergeObj;\n }\n\n // If the merge object is an empty object, and the initial object is not undefined, we return the initial object\n if (initialObj && Object.keys(mergeObj).length === 0) {\n return initialObj;\n }\n\n // Clone object\n const output = { ...initialObj };\n\n // Merge values into output, resursively\n for (const key in mergeObj) {\n if (Object.prototype.hasOwnProperty.call(mergeObj, key)) {\n output[key] = merge(output[key], mergeObj[key], levels - 1);\n }\n }\n\n return output;\n}\n\nexport { merge };\n//# sourceMappingURL=merge.js.map\n","import { uuid4 } from './misc.js';\n\n/**\n * Generate a random, valid trace ID.\n */\nfunction generateTraceId() {\n return uuid4();\n}\n\n/**\n * Generate a random, valid span ID.\n */\nfunction generateSpanId() {\n return uuid4().substring(16);\n}\n\nexport { generateSpanId, generateTraceId };\n//# sourceMappingURL=propagationContext.js.map\n","import { addNonEnumerableProperty } from './object.js';\n\nconst SCOPE_SPAN_FIELD = '_sentrySpan';\n\n/**\n * Set the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _setSpanForScope(scope, span) {\n if (span) {\n addNonEnumerableProperty(scope , SCOPE_SPAN_FIELD, span);\n } else {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete (scope )[SCOPE_SPAN_FIELD];\n }\n}\n\n/**\n * Get the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _getSpanForScope(scope) {\n return scope[SCOPE_SPAN_FIELD];\n}\n\nexport { _getSpanForScope, _setSpanForScope };\n//# sourceMappingURL=spanOnScope.js.map\n","import { DEBUG_BUILD } from './debug-build.js';\nimport { updateSession } from './session.js';\nimport { debug } from './utils/debug-logger.js';\nimport { isPlainObject } from './utils/is.js';\nimport { merge } from './utils/merge.js';\nimport { uuid4 } from './utils/misc.js';\nimport { generateTraceId } from './utils/propagationContext.js';\nimport { _setSpanForScope, _getSpanForScope } from './utils/spanOnScope.js';\nimport { truncate } from './utils/string.js';\nimport { dateTimestampInSeconds } from './utils/time.js';\n\n/**\n * Default value for maximum number of breadcrumbs added to an event.\n */\nconst DEFAULT_MAX_BREADCRUMBS = 100;\n\n/**\n * A context to be used for capturing an event.\n * This can either be a Scope, or a partial ScopeContext,\n * or a callback that receives the current scope and returns a new scope to use.\n */\n\n/**\n * Holds additional event information.\n */\nclass Scope {\n /** Flag if notifying is happening. */\n\n /** Callback for client to receive scope changes. */\n\n /** Callback list that will be called during event processing. */\n\n /** Array of breadcrumbs. */\n\n /** User */\n\n /** Tags */\n\n /** Extra */\n\n /** Contexts */\n\n /** Attachments */\n\n /** Propagation Context for distributed tracing */\n\n /**\n * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get\n * sent to Sentry\n */\n\n /** Fingerprint */\n\n /** Severity */\n\n /**\n * Transaction Name\n *\n * IMPORTANT: The transaction name on the scope has nothing to do with root spans/transaction objects.\n * It's purpose is to assign a transaction to the scope that's added to non-transaction events.\n */\n\n /** Session */\n\n /** The client on this scope */\n\n /** Contains the last event id of a captured event. */\n\n // NOTE: Any field which gets added here should get added not only to the constructor but also to the `clone` method.\n\n constructor() {\n this._notifyingListeners = false;\n this._scopeListeners = [];\n this._eventProcessors = [];\n this._breadcrumbs = [];\n this._attachments = [];\n this._user = {};\n this._tags = {};\n this._extra = {};\n this._contexts = {};\n this._sdkProcessingMetadata = {};\n this._propagationContext = {\n traceId: generateTraceId(),\n sampleRand: Math.random(),\n };\n }\n\n /**\n * Clone all data from this scope into a new scope.\n */\n clone() {\n const newScope = new Scope();\n newScope._breadcrumbs = [...this._breadcrumbs];\n newScope._tags = { ...this._tags };\n newScope._extra = { ...this._extra };\n newScope._contexts = { ...this._contexts };\n if (this._contexts.flags) {\n // We need to copy the `values` array so insertions on a cloned scope\n // won't affect the original array.\n newScope._contexts.flags = {\n values: [...this._contexts.flags.values],\n };\n }\n\n newScope._user = this._user;\n newScope._level = this._level;\n newScope._session = this._session;\n newScope._transactionName = this._transactionName;\n newScope._fingerprint = this._fingerprint;\n newScope._eventProcessors = [...this._eventProcessors];\n newScope._attachments = [...this._attachments];\n newScope._sdkProcessingMetadata = { ...this._sdkProcessingMetadata };\n newScope._propagationContext = { ...this._propagationContext };\n newScope._client = this._client;\n newScope._lastEventId = this._lastEventId;\n\n _setSpanForScope(newScope, _getSpanForScope(this));\n\n return newScope;\n }\n\n /**\n * Update the client assigned to this scope.\n * Note that not every scope will have a client assigned - isolation scopes & the global scope will generally not have a client,\n * as well as manually created scopes.\n */\n setClient(client) {\n this._client = client;\n }\n\n /**\n * Set the ID of the last captured error event.\n * This is generally only captured on the isolation scope.\n */\n setLastEventId(lastEventId) {\n this._lastEventId = lastEventId;\n }\n\n /**\n * Get the client assigned to this scope.\n */\n getClient() {\n return this._client ;\n }\n\n /**\n * Get the ID of the last captured error event.\n * This is generally only available on the isolation scope.\n */\n lastEventId() {\n return this._lastEventId;\n }\n\n /**\n * @inheritDoc\n */\n addScopeListener(callback) {\n this._scopeListeners.push(callback);\n }\n\n /**\n * Add an event processor that will be called before an event is sent.\n */\n addEventProcessor(callback) {\n this._eventProcessors.push(callback);\n return this;\n }\n\n /**\n * Set the user for this scope.\n * Set to `null` to unset the user.\n */\n setUser(user) {\n // If null is passed we want to unset everything, but still define keys,\n // so that later down in the pipeline any existing values are cleared.\n this._user = user || {\n email: undefined,\n id: undefined,\n ip_address: undefined,\n username: undefined,\n };\n\n if (this._session) {\n updateSession(this._session, { user });\n }\n\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Get the user from this scope.\n */\n getUser() {\n return this._user;\n }\n\n /**\n * Set an object that will be merged into existing tags on the scope,\n * and will be sent as tags data with the event.\n */\n setTags(tags) {\n this._tags = {\n ...this._tags,\n ...tags,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Set a single tag that will be sent as tags data with the event.\n */\n setTag(key, value) {\n this._tags = { ...this._tags, [key]: value };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Set an object that will be merged into existing extra on the scope,\n * and will be sent as extra data with the event.\n */\n setExtras(extras) {\n this._extra = {\n ...this._extra,\n ...extras,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Set a single key:value extra entry that will be sent as extra data with the event.\n */\n setExtra(key, extra) {\n this._extra = { ...this._extra, [key]: extra };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Sets the fingerprint on the scope to send with the events.\n * @param {string[]} fingerprint Fingerprint to group events in Sentry.\n */\n setFingerprint(fingerprint) {\n this._fingerprint = fingerprint;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Sets the level on the scope for future events.\n */\n setLevel(level) {\n this._level = level;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Sets the transaction name on the scope so that the name of e.g. taken server route or\n * the page location is attached to future events.\n *\n * IMPORTANT: Calling this function does NOT change the name of the currently active\n * root span. If you want to change the name of the active root span, use\n * `Sentry.updateSpanName(rootSpan, 'new name')` instead.\n *\n * By default, the SDK updates the scope's transaction name automatically on sensible\n * occasions, such as a page navigation or when handling a new request on the server.\n */\n setTransactionName(name) {\n this._transactionName = name;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Sets context data with the given name.\n * Data passed as context will be normalized. You can also pass `null` to unset the context.\n * Note that context data will not be merged - calling `setContext` will overwrite an existing context with the same key.\n */\n setContext(key, context) {\n if (context === null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this._contexts[key];\n } else {\n this._contexts[key] = context;\n }\n\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Set the session for the scope.\n */\n setSession(session) {\n if (!session) {\n delete this._session;\n } else {\n this._session = session;\n }\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Get the session from the scope.\n */\n getSession() {\n return this._session;\n }\n\n /**\n * Updates the scope with provided data. Can work in three variations:\n * - plain object containing updatable attributes\n * - Scope instance that'll extract the attributes from\n * - callback function that'll receive the current scope as an argument and allow for modifications\n */\n update(captureContext) {\n if (!captureContext) {\n return this;\n }\n\n const scopeToMerge = typeof captureContext === 'function' ? captureContext(this) : captureContext;\n\n const scopeInstance =\n scopeToMerge instanceof Scope\n ? scopeToMerge.getScopeData()\n : isPlainObject(scopeToMerge)\n ? (captureContext )\n : undefined;\n\n const { tags, extra, user, contexts, level, fingerprint = [], propagationContext } = scopeInstance || {};\n\n this._tags = { ...this._tags, ...tags };\n this._extra = { ...this._extra, ...extra };\n this._contexts = { ...this._contexts, ...contexts };\n\n if (user && Object.keys(user).length) {\n this._user = user;\n }\n\n if (level) {\n this._level = level;\n }\n\n if (fingerprint.length) {\n this._fingerprint = fingerprint;\n }\n\n if (propagationContext) {\n this._propagationContext = propagationContext;\n }\n\n return this;\n }\n\n /**\n * Clears the current scope and resets its properties.\n * Note: The client will not be cleared.\n */\n clear() {\n // client is not cleared here on purpose!\n this._breadcrumbs = [];\n this._tags = {};\n this._extra = {};\n this._user = {};\n this._contexts = {};\n this._level = undefined;\n this._transactionName = undefined;\n this._fingerprint = undefined;\n this._session = undefined;\n _setSpanForScope(this, undefined);\n this._attachments = [];\n this.setPropagationContext({ traceId: generateTraceId(), sampleRand: Math.random() });\n\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Adds a breadcrumb to the scope.\n * By default, the last 100 breadcrumbs are kept.\n */\n addBreadcrumb(breadcrumb, maxBreadcrumbs) {\n const maxCrumbs = typeof maxBreadcrumbs === 'number' ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS;\n\n // No data has been changed, so don't notify scope listeners\n if (maxCrumbs <= 0) {\n return this;\n }\n\n const mergedBreadcrumb = {\n timestamp: dateTimestampInSeconds(),\n ...breadcrumb,\n // Breadcrumb messages can theoretically be infinitely large and they're held in memory so we truncate them not to leak (too much) memory\n message: breadcrumb.message ? truncate(breadcrumb.message, 2048) : breadcrumb.message,\n };\n\n this._breadcrumbs.push(mergedBreadcrumb);\n if (this._breadcrumbs.length > maxCrumbs) {\n this._breadcrumbs = this._breadcrumbs.slice(-maxCrumbs);\n this._client?.recordDroppedEvent('buffer_overflow', 'log_item');\n }\n\n this._notifyScopeListeners();\n\n return this;\n }\n\n /**\n * Get the last breadcrumb of the scope.\n */\n getLastBreadcrumb() {\n return this._breadcrumbs[this._breadcrumbs.length - 1];\n }\n\n /**\n * Clear all breadcrumbs from the scope.\n */\n clearBreadcrumbs() {\n this._breadcrumbs = [];\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * Add an attachment to the scope.\n */\n addAttachment(attachment) {\n this._attachments.push(attachment);\n return this;\n }\n\n /**\n * Clear all attachments from the scope.\n */\n clearAttachments() {\n this._attachments = [];\n return this;\n }\n\n /**\n * Get the data of this scope, which should be applied to an event during processing.\n */\n getScopeData() {\n return {\n breadcrumbs: this._breadcrumbs,\n attachments: this._attachments,\n contexts: this._contexts,\n tags: this._tags,\n extra: this._extra,\n user: this._user,\n level: this._level,\n fingerprint: this._fingerprint || [],\n eventProcessors: this._eventProcessors,\n propagationContext: this._propagationContext,\n sdkProcessingMetadata: this._sdkProcessingMetadata,\n transactionName: this._transactionName,\n span: _getSpanForScope(this),\n };\n }\n\n /**\n * Add data which will be accessible during event processing but won't get sent to Sentry.\n */\n setSDKProcessingMetadata(newData) {\n this._sdkProcessingMetadata = merge(this._sdkProcessingMetadata, newData, 2);\n return this;\n }\n\n /**\n * Add propagation context to the scope, used for distributed tracing\n */\n setPropagationContext(context) {\n this._propagationContext = context;\n return this;\n }\n\n /**\n * Get propagation context from the scope, used for distributed tracing\n */\n getPropagationContext() {\n return this._propagationContext;\n }\n\n /**\n * Capture an exception for this scope.\n *\n * @returns {string} The id of the captured Sentry event.\n */\n captureException(exception, hint) {\n const eventId = hint?.event_id || uuid4();\n\n if (!this._client) {\n DEBUG_BUILD && debug.warn('No client configured on scope - will not capture exception!');\n return eventId;\n }\n\n const syntheticException = new Error('Sentry syntheticException');\n\n this._client.captureException(\n exception,\n {\n originalException: exception,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n this,\n );\n\n return eventId;\n }\n\n /**\n * Capture a message for this scope.\n *\n * @returns {string} The id of the captured message.\n */\n captureMessage(message, level, hint) {\n const eventId = hint?.event_id || uuid4();\n\n if (!this._client) {\n DEBUG_BUILD && debug.warn('No client configured on scope - will not capture message!');\n return eventId;\n }\n\n const syntheticException = new Error(message);\n\n this._client.captureMessage(\n message,\n level,\n {\n originalException: message,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n this,\n );\n\n return eventId;\n }\n\n /**\n * Capture a Sentry event for this scope.\n *\n * @returns {string} The id of the captured event.\n */\n captureEvent(event, hint) {\n const eventId = hint?.event_id || uuid4();\n\n if (!this._client) {\n DEBUG_BUILD && debug.warn('No client configured on scope - will not capture event!');\n return eventId;\n }\n\n this._client.captureEvent(event, { ...hint, event_id: eventId }, this);\n\n return eventId;\n }\n\n /**\n * This will be called on every set call.\n */\n _notifyScopeListeners() {\n // We need this check for this._notifyingListeners to be able to work on scope during updates\n // If this check is not here we'll produce endless recursion when something is done with the scope\n // during the callback.\n if (!this._notifyingListeners) {\n this._notifyingListeners = true;\n this._scopeListeners.forEach(callback => {\n callback(this);\n });\n this._notifyingListeners = false;\n }\n }\n}\n\nexport { Scope };\n//# sourceMappingURL=scope.js.map\n","import { getGlobalSingleton } from './carrier.js';\nimport { Scope } from './scope.js';\n\n/** Get the default current scope. */\nfunction getDefaultCurrentScope() {\n return getGlobalSingleton('defaultCurrentScope', () => new Scope());\n}\n\n/** Get the default isolation scope. */\nfunction getDefaultIsolationScope() {\n return getGlobalSingleton('defaultIsolationScope', () => new Scope());\n}\n\nexport { getDefaultCurrentScope, getDefaultIsolationScope };\n//# sourceMappingURL=defaultScopes.js.map\n","import { getDefaultCurrentScope, getDefaultIsolationScope } from '../defaultScopes.js';\nimport { Scope } from '../scope.js';\nimport { isThenable } from '../utils/is.js';\nimport { getMainCarrier, getSentryCarrier } from '../carrier.js';\n\n/**\n * This is an object that holds a stack of scopes.\n */\nclass AsyncContextStack {\n\n constructor(scope, isolationScope) {\n let assignedScope;\n if (!scope) {\n assignedScope = new Scope();\n } else {\n assignedScope = scope;\n }\n\n let assignedIsolationScope;\n if (!isolationScope) {\n assignedIsolationScope = new Scope();\n } else {\n assignedIsolationScope = isolationScope;\n }\n\n // scope stack for domains or the process\n this._stack = [{ scope: assignedScope }];\n this._isolationScope = assignedIsolationScope;\n }\n\n /**\n * Fork a scope for the stack.\n */\n withScope(callback) {\n const scope = this._pushScope();\n\n let maybePromiseResult;\n try {\n maybePromiseResult = callback(scope);\n } catch (e) {\n this._popScope();\n throw e;\n }\n\n if (isThenable(maybePromiseResult)) {\n // @ts-expect-error - isThenable returns the wrong type\n return maybePromiseResult.then(\n res => {\n this._popScope();\n return res;\n },\n e => {\n this._popScope();\n throw e;\n },\n );\n }\n\n this._popScope();\n return maybePromiseResult;\n }\n\n /**\n * Get the client of the stack.\n */\n getClient() {\n return this.getStackTop().client ;\n }\n\n /**\n * Returns the scope of the top stack.\n */\n getScope() {\n return this.getStackTop().scope;\n }\n\n /**\n * Get the isolation scope for the stack.\n */\n getIsolationScope() {\n return this._isolationScope;\n }\n\n /**\n * Returns the topmost scope layer in the order domain > local > process.\n */\n getStackTop() {\n return this._stack[this._stack.length - 1] ;\n }\n\n /**\n * Push a scope to the stack.\n */\n _pushScope() {\n // We want to clone the content of prev scope\n const scope = this.getScope().clone();\n this._stack.push({\n client: this.getClient(),\n scope,\n });\n return scope;\n }\n\n /**\n * Pop a scope from the stack.\n */\n _popScope() {\n if (this._stack.length <= 1) return false;\n return !!this._stack.pop();\n }\n}\n\n/**\n * Get the global async context stack.\n * This will be removed during the v8 cycle and is only here to make migration easier.\n */\nfunction getAsyncContextStack() {\n const registry = getMainCarrier();\n const sentry = getSentryCarrier(registry);\n\n return (sentry.stack = sentry.stack || new AsyncContextStack(getDefaultCurrentScope(), getDefaultIsolationScope()));\n}\n\nfunction withScope(callback) {\n return getAsyncContextStack().withScope(callback);\n}\n\nfunction withSetScope(scope, callback) {\n const stack = getAsyncContextStack();\n return stack.withScope(() => {\n stack.getStackTop().scope = scope;\n return callback(scope);\n });\n}\n\nfunction withIsolationScope(callback) {\n return getAsyncContextStack().withScope(() => {\n return callback(getAsyncContextStack().getIsolationScope());\n });\n}\n\n/**\n * Get the stack-based async context strategy.\n */\nfunction getStackAsyncContextStrategy() {\n return {\n withIsolationScope,\n withScope,\n withSetScope,\n withSetIsolationScope: (_isolationScope, callback) => {\n return withIsolationScope(callback);\n },\n getCurrentScope: () => getAsyncContextStack().getScope(),\n getIsolationScope: () => getAsyncContextStack().getIsolationScope(),\n };\n}\n\nexport { AsyncContextStack, getStackAsyncContextStrategy };\n//# sourceMappingURL=stackStrategy.js.map\n","import { getMainCarrier, getSentryCarrier } from '../carrier.js';\nimport { getStackAsyncContextStrategy } from './stackStrategy.js';\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Sets the global async context strategy\n */\nfunction setAsyncContextStrategy(strategy) {\n // Get main carrier (global for every environment)\n const registry = getMainCarrier();\n const sentry = getSentryCarrier(registry);\n sentry.acs = strategy;\n}\n\n/**\n * Get the current async context strategy.\n * If none has been setup, the default will be used.\n */\nfunction getAsyncContextStrategy(carrier) {\n const sentry = getSentryCarrier(carrier);\n\n if (sentry.acs) {\n return sentry.acs;\n }\n\n // Otherwise, use the default one (stack)\n return getStackAsyncContextStrategy();\n}\n\nexport { getAsyncContextStrategy, setAsyncContextStrategy };\n//# sourceMappingURL=index.js.map\n","import { getAsyncContextStrategy } from './asyncContext/index.js';\nimport { getMainCarrier, getGlobalSingleton } from './carrier.js';\nimport { Scope } from './scope.js';\nimport { generateSpanId } from './utils/propagationContext.js';\n\n/**\n * Get the currently active scope.\n */\nfunction getCurrentScope() {\n const carrier = getMainCarrier();\n const acs = getAsyncContextStrategy(carrier);\n return acs.getCurrentScope();\n}\n\n/**\n * Get the currently active isolation scope.\n * The isolation scope is active for the current execution context.\n */\nfunction getIsolationScope() {\n const carrier = getMainCarrier();\n const acs = getAsyncContextStrategy(carrier);\n return acs.getIsolationScope();\n}\n\n/**\n * Get the global scope.\n * This scope is applied to _all_ events.\n */\nfunction getGlobalScope() {\n return getGlobalSingleton('globalScope', () => new Scope());\n}\n\n/**\n * Creates a new scope with and executes the given operation within.\n * The scope is automatically removed once the operation\n * finishes or throws.\n */\n\n/**\n * Either creates a new active scope, or sets the given scope as active scope in the given callback.\n */\nfunction withScope(\n ...rest\n) {\n const carrier = getMainCarrier();\n const acs = getAsyncContextStrategy(carrier);\n\n // If a scope is defined, we want to make this the active scope instead of the default one\n if (rest.length === 2) {\n const [scope, callback] = rest;\n\n if (!scope) {\n return acs.withScope(callback);\n }\n\n return acs.withSetScope(scope, callback);\n }\n\n return acs.withScope(rest[0]);\n}\n\n/**\n * Attempts to fork the current isolation scope and the current scope based on the current async context strategy. If no\n * async context strategy is set, the isolation scope and the current scope will not be forked (this is currently the\n * case, for example, in the browser).\n *\n * Usage of this function in environments without async context strategy is discouraged and may lead to unexpected behaviour.\n *\n * This function is intended for Sentry SDK and SDK integration development. It is not recommended to be used in \"normal\"\n * applications directly because it comes with pitfalls. Use at your own risk!\n */\n\n/**\n * Either creates a new active isolation scope, or sets the given isolation scope as active scope in the given callback.\n */\nfunction withIsolationScope(\n ...rest\n\n) {\n const carrier = getMainCarrier();\n const acs = getAsyncContextStrategy(carrier);\n\n // If a scope is defined, we want to make this the active scope instead of the default one\n if (rest.length === 2) {\n const [isolationScope, callback] = rest;\n\n if (!isolationScope) {\n return acs.withIsolationScope(callback);\n }\n\n return acs.withSetIsolationScope(isolationScope, callback);\n }\n\n return acs.withIsolationScope(rest[0]);\n}\n\n/**\n * Get the currently active client.\n */\nfunction getClient() {\n return getCurrentScope().getClient();\n}\n\n/**\n * Get a trace context for the given scope.\n */\nfunction getTraceContextFromScope(scope) {\n const propagationContext = scope.getPropagationContext();\n\n const { traceId, parentSpanId, propagationSpanId } = propagationContext;\n\n const traceContext = {\n trace_id: traceId,\n span_id: propagationSpanId || generateSpanId(),\n };\n\n if (parentSpanId) {\n traceContext.parent_span_id = parentSpanId;\n }\n\n return traceContext;\n}\n\nexport { getClient, getCurrentScope, getGlobalScope, getIsolationScope, getTraceContextFromScope, withIsolationScope, withScope };\n//# sourceMappingURL=currentScopes.js.map\n","/**\n * Use this attribute to represent the source of a span.\n * Should be one of: custom, url, route, view, component, task, unknown\n *\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = 'sentry.source';\n\n/**\n * Attributes that holds the sample rate that was locally applied to a span.\n * If this attribute is not defined, it means that the span inherited a sampling decision.\n *\n * NOTE: Is only defined on root spans.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = 'sentry.sample_rate';\n\n/**\n * Attribute holding the sample rate of the previous trace.\n * This is used to sample consistently across subsequent traces in the browser SDK.\n *\n * Note: Only defined on root spans, if opted into consistent sampling\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = 'sentry.previous_trace_sample_rate';\n\n/**\n * Use this attribute to represent the operation of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_OP = 'sentry.op';\n\n/**\n * Use this attribute to represent the origin of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = 'sentry.origin';\n\n/** The reason why an idle span finished. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = 'sentry.idle_span_finish_reason';\n\n/** The unit of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = 'sentry.measurement_unit';\n\n/** The value of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = 'sentry.measurement_value';\n\n/**\n * A custom span name set by users guaranteed to be taken over any automatically\n * inferred name. This attribute is removed before the span is sent.\n *\n * @internal only meant for internal SDK usage\n * @hidden\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = 'sentry.custom_span_name';\n\n/**\n * The id of the profile that this span occurred in.\n */\nconst SEMANTIC_ATTRIBUTE_PROFILE_ID = 'sentry.profile_id';\n\nconst SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = 'sentry.exclusive_time';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_HIT = 'cache.hit';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_KEY = 'cache.key';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = 'cache.item_size';\n\n/** TODO: Remove these once we update to latest semantic conventions */\nconst SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = 'http.request.method';\nconst SEMANTIC_ATTRIBUTE_URL_FULL = 'url.full';\n\n/**\n * A span link attribute to mark the link as a special span link.\n *\n * Known values:\n * - `previous_trace`: The span links to the frontend root span of the previous trace.\n * - `next_trace`: The span links to the frontend root span of the next trace. (Not set by the SDK)\n *\n * Other values may be set as appropriate.\n * @see https://develop.sentry.dev/sdk/telemetry/traces/span-links/#link-types\n */\nconst SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = 'sentry.link.type';\n\nexport { SEMANTIC_ATTRIBUTE_CACHE_HIT, SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE, SEMANTIC_ATTRIBUTE_CACHE_KEY, SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME, SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD, SEMANTIC_ATTRIBUTE_PROFILE_ID, SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME, SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON, SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT, SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE, SEMANTIC_ATTRIBUTE_SENTRY_OP, SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN, SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE, SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE, SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, SEMANTIC_ATTRIBUTE_URL_FULL, SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE };\n//# sourceMappingURL=semanticAttributes.js.map\n","const SPAN_STATUS_UNSET = 0;\nconst SPAN_STATUS_OK = 1;\nconst SPAN_STATUS_ERROR = 2;\n\n/**\n * Converts a HTTP status code into a sentry status with a message.\n *\n * @param httpStatus The HTTP response status code.\n * @returns The span status or unknown_error.\n */\n// https://develop.sentry.dev/sdk/event-payloads/span/\nfunction getSpanStatusFromHttpCode(httpStatus) {\n if (httpStatus < 400 && httpStatus >= 100) {\n return { code: SPAN_STATUS_OK };\n }\n\n if (httpStatus >= 400 && httpStatus < 500) {\n switch (httpStatus) {\n case 401:\n return { code: SPAN_STATUS_ERROR, message: 'unauthenticated' };\n case 403:\n return { code: SPAN_STATUS_ERROR, message: 'permission_denied' };\n case 404:\n return { code: SPAN_STATUS_ERROR, message: 'not_found' };\n case 409:\n return { code: SPAN_STATUS_ERROR, message: 'already_exists' };\n case 413:\n return { code: SPAN_STATUS_ERROR, message: 'failed_precondition' };\n case 429:\n return { code: SPAN_STATUS_ERROR, message: 'resource_exhausted' };\n case 499:\n return { code: SPAN_STATUS_ERROR, message: 'cancelled' };\n default:\n return { code: SPAN_STATUS_ERROR, message: 'invalid_argument' };\n }\n }\n\n if (httpStatus >= 500 && httpStatus < 600) {\n switch (httpStatus) {\n case 501:\n return { code: SPAN_STATUS_ERROR, message: 'unimplemented' };\n case 503:\n return { code: SPAN_STATUS_ERROR, message: 'unavailable' };\n case 504:\n return { code: SPAN_STATUS_ERROR, message: 'deadline_exceeded' };\n default:\n return { code: SPAN_STATUS_ERROR, message: 'internal_error' };\n }\n }\n\n return { code: SPAN_STATUS_ERROR, message: 'unknown_error' };\n}\n\n/**\n * Sets the Http status attributes on the current span based on the http code.\n * Additionally, the span's status is updated, depending on the http code.\n */\nfunction setHttpStatus(span, httpStatus) {\n span.setAttribute('http.response.status_code', httpStatus);\n\n const spanStatus = getSpanStatusFromHttpCode(httpStatus);\n if (spanStatus.message !== 'unknown_error') {\n span.setStatus(spanStatus);\n }\n}\n\nexport { SPAN_STATUS_ERROR, SPAN_STATUS_OK, SPAN_STATUS_UNSET, getSpanStatusFromHttpCode, setHttpStatus };\n//# sourceMappingURL=spanstatus.js.map\n","import { addNonEnumerableProperty } from '../utils/object.js';\nimport { GLOBAL_OBJ } from '../utils/worldwide.js';\n\nconst SCOPE_ON_START_SPAN_FIELD = '_sentryScope';\nconst ISOLATION_SCOPE_ON_START_SPAN_FIELD = '_sentryIsolationScope';\n\n/** Wrap a scope with a WeakRef if available, falling back to a direct scope. */\nfunction wrapScopeWithWeakRef(scope) {\n try {\n // @ts-expect-error - WeakRef is not available in all environments\n const WeakRefClass = GLOBAL_OBJ.WeakRef;\n if (typeof WeakRefClass === 'function') {\n return new WeakRefClass(scope);\n }\n } catch {\n // WeakRef not available or failed to create\n // We'll fall back to a direct scope\n }\n\n return scope;\n}\n\n/** Try to unwrap a scope from a potential WeakRef wrapper. */\nfunction unwrapScopeFromWeakRef(scopeRef) {\n if (!scopeRef) {\n return undefined;\n }\n\n if (typeof scopeRef === 'object' && 'deref' in scopeRef && typeof scopeRef.deref === 'function') {\n try {\n return scopeRef.deref();\n } catch {\n return undefined;\n }\n }\n\n // Fallback to a direct scope\n return scopeRef ;\n}\n\n/** Store the scope & isolation scope for a span, which can the be used when it is finished. */\nfunction setCapturedScopesOnSpan(span, scope, isolationScope) {\n if (span) {\n addNonEnumerableProperty(span, ISOLATION_SCOPE_ON_START_SPAN_FIELD, wrapScopeWithWeakRef(isolationScope));\n // We don't wrap the scope with a WeakRef here because webkit aggressively garbage collects\n // and scopes are not held in memory for long periods of time.\n addNonEnumerableProperty(span, SCOPE_ON_START_SPAN_FIELD, scope);\n }\n}\n\n/**\n * Grabs the scope and isolation scope off a span that were active when the span was started.\n * If WeakRef was used and scopes have been garbage collected, returns undefined for those scopes.\n */\nfunction getCapturedScopesOnSpan(span) {\n const spanWithScopes = span ;\n\n return {\n scope: spanWithScopes[SCOPE_ON_START_SPAN_FIELD],\n isolationScope: unwrapScopeFromWeakRef(spanWithScopes[ISOLATION_SCOPE_ON_START_SPAN_FIELD]),\n };\n}\n\nexport { getCapturedScopesOnSpan, setCapturedScopesOnSpan };\n//# sourceMappingURL=utils.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { debug } from './debug-logger.js';\nimport { isString } from './is.js';\n\nconst SENTRY_BAGGAGE_KEY_PREFIX = 'sentry-';\n\nconst SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/;\n\n/**\n * Max length of a serialized baggage string\n *\n * https://www.w3.org/TR/baggage/#limits\n */\nconst MAX_BAGGAGE_STRING_LENGTH = 8192;\n\n/**\n * Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the \"sentry-\" prefixed values\n * from it.\n *\n * @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks.\n * @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise.\n */\nfunction baggageHeaderToDynamicSamplingContext(\n // Very liberal definition of what any incoming header might look like\n baggageHeader,\n) {\n const baggageObject = parseBaggageHeader(baggageHeader);\n\n if (!baggageObject) {\n return undefined;\n }\n\n // Read all \"sentry-\" prefixed values out of the baggage object and put it onto a dynamic sampling context object.\n const dynamicSamplingContext = Object.entries(baggageObject).reduce((acc, [key, value]) => {\n if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) {\n const nonPrefixedKey = key.slice(SENTRY_BAGGAGE_KEY_PREFIX.length);\n acc[nonPrefixedKey] = value;\n }\n return acc;\n }, {});\n\n // Only return a dynamic sampling context object if there are keys in it.\n // A keyless object means there were no sentry values on the header, which means that there is no DSC.\n if (Object.keys(dynamicSamplingContext).length > 0) {\n return dynamicSamplingContext ;\n } else {\n return undefined;\n }\n}\n\n/**\n * Turns a Dynamic Sampling Object into a baggage header by prefixing all the keys on the object with \"sentry-\".\n *\n * @param dynamicSamplingContext The Dynamic Sampling Context to turn into a header. For convenience and compatibility\n * with the `getDynamicSamplingContext` method on the Transaction class ,this argument can also be `undefined`. If it is\n * `undefined` the function will return `undefined`.\n * @returns a baggage header, created from `dynamicSamplingContext`, or `undefined` either if `dynamicSamplingContext`\n * was `undefined`, or if `dynamicSamplingContext` didn't contain any values.\n */\nfunction dynamicSamplingContextToSentryBaggageHeader(\n // this also takes undefined for convenience and bundle size in other places\n dynamicSamplingContext,\n) {\n if (!dynamicSamplingContext) {\n return undefined;\n }\n\n // Prefix all DSC keys with \"sentry-\" and put them into a new object\n const sentryPrefixedDSC = Object.entries(dynamicSamplingContext).reduce(\n (acc, [dscKey, dscValue]) => {\n if (dscValue) {\n acc[`${SENTRY_BAGGAGE_KEY_PREFIX}${dscKey}`] = dscValue;\n }\n return acc;\n },\n {},\n );\n\n return objectToBaggageHeader(sentryPrefixedDSC);\n}\n\n/**\n * Take a baggage header and parse it into an object.\n */\nfunction parseBaggageHeader(\n baggageHeader,\n) {\n if (!baggageHeader || (!isString(baggageHeader) && !Array.isArray(baggageHeader))) {\n return undefined;\n }\n\n if (Array.isArray(baggageHeader)) {\n // Combine all baggage headers into one object containing the baggage values so we can later read the Sentry-DSC-values from it\n return baggageHeader.reduce((acc, curr) => {\n const currBaggageObject = baggageHeaderToObject(curr);\n Object.entries(currBaggageObject).forEach(([key, value]) => {\n acc[key] = value;\n });\n return acc;\n }, {});\n }\n\n return baggageHeaderToObject(baggageHeader);\n}\n\n/**\n * Will parse a baggage header, which is a simple key-value map, into a flat object.\n *\n * @param baggageHeader The baggage header to parse.\n * @returns a flat object containing all the key-value pairs from `baggageHeader`.\n */\nfunction baggageHeaderToObject(baggageHeader) {\n return baggageHeader\n .split(',')\n .map(baggageEntry => {\n const eqIdx = baggageEntry.indexOf('=');\n if (eqIdx === -1) {\n // Likely an invalid entry\n return [];\n }\n const key = baggageEntry.slice(0, eqIdx);\n const value = baggageEntry.slice(eqIdx + 1);\n return [key, value].map(keyOrValue => {\n try {\n return decodeURIComponent(keyOrValue.trim());\n } catch {\n // We ignore errors here, e.g. if the value cannot be URL decoded.\n // This will then be skipped in the next step\n return;\n }\n });\n })\n .reduce((acc, [key, value]) => {\n if (key && value) {\n acc[key] = value;\n }\n return acc;\n }, {});\n}\n\n/**\n * Turns a flat object (key-value pairs) into a baggage header, which is also just key-value pairs.\n *\n * @param object The object to turn into a baggage header.\n * @returns a baggage header string, or `undefined` if the object didn't have any values, since an empty baggage header\n * is not spec compliant.\n */\nfunction objectToBaggageHeader(object) {\n if (Object.keys(object).length === 0) {\n // An empty baggage header is not spec compliant: We return undefined.\n return undefined;\n }\n\n return Object.entries(object).reduce((baggageHeader, [objectKey, objectValue], currentIndex) => {\n const baggageEntry = `${encodeURIComponent(objectKey)}=${encodeURIComponent(objectValue)}`;\n const newBaggageHeader = currentIndex === 0 ? baggageEntry : `${baggageHeader},${baggageEntry}`;\n if (newBaggageHeader.length > MAX_BAGGAGE_STRING_LENGTH) {\n DEBUG_BUILD &&\n debug.warn(\n `Not adding key: ${objectKey} with val: ${objectValue} to baggage header due to exceeding baggage size limits.`,\n );\n return baggageHeader;\n } else {\n return newBaggageHeader;\n }\n }, '');\n}\n\nexport { MAX_BAGGAGE_STRING_LENGTH, SENTRY_BAGGAGE_KEY_PREFIX, SENTRY_BAGGAGE_KEY_PREFIX_REGEX, baggageHeaderToDynamicSamplingContext, dynamicSamplingContextToSentryBaggageHeader, objectToBaggageHeader, parseBaggageHeader };\n//# sourceMappingURL=baggage.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { consoleSandbox, debug } from './debug-logger.js';\n\n/** Regular expression used to extract org ID from a DSN host. */\nconst ORG_ID_REGEX = /^o(\\d+)\\./;\n\n/** Regular expression used to parse a Dsn. */\nconst DSN_REGEX = /^(?:(\\w+):)\\/\\/(?:(\\w+)(?::(\\w+)?)?@)([\\w.-]+)(?::(\\d+))?\\/(.+)/;\n\nfunction isValidProtocol(protocol) {\n return protocol === 'http' || protocol === 'https';\n}\n\n/**\n * Renders the string representation of this Dsn.\n *\n * By default, this will render the public representation without the password\n * component. To get the deprecated private representation, set `withPassword`\n * to true.\n *\n * @param withPassword When set to true, the password will be included.\n */\nfunction dsnToString(dsn, withPassword = false) {\n const { host, path, pass, port, projectId, protocol, publicKey } = dsn;\n return (\n `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ''}` +\n `@${host}${port ? `:${port}` : ''}/${path ? `${path}/` : path}${projectId}`\n );\n}\n\n/**\n * Parses a Dsn from a given string.\n *\n * @param str A Dsn as string\n * @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string\n */\nfunction dsnFromString(str) {\n const match = DSN_REGEX.exec(str);\n\n if (!match) {\n // This should be logged to the console\n consoleSandbox(() => {\n // eslint-disable-next-line no-console\n console.error(`Invalid Sentry Dsn: ${str}`);\n });\n return undefined;\n }\n\n const [protocol, publicKey, pass = '', host = '', port = '', lastPath = ''] = match.slice(1);\n let path = '';\n let projectId = lastPath;\n\n const split = projectId.split('/');\n if (split.length > 1) {\n path = split.slice(0, -1).join('/');\n projectId = split.pop() ;\n }\n\n if (projectId) {\n const projectMatch = projectId.match(/^\\d+/);\n if (projectMatch) {\n projectId = projectMatch[0];\n }\n }\n\n return dsnFromComponents({ host, pass, path, projectId, port, protocol: protocol , publicKey });\n}\n\nfunction dsnFromComponents(components) {\n return {\n protocol: components.protocol,\n publicKey: components.publicKey || '',\n pass: components.pass || '',\n host: components.host,\n port: components.port || '',\n path: components.path || '',\n projectId: components.projectId,\n };\n}\n\nfunction validateDsn(dsn) {\n if (!DEBUG_BUILD) {\n return true;\n }\n\n const { port, projectId, protocol } = dsn;\n\n const requiredComponents = ['protocol', 'publicKey', 'host', 'projectId'];\n const hasMissingRequiredComponent = requiredComponents.find(component => {\n if (!dsn[component]) {\n debug.error(`Invalid Sentry Dsn: ${component} missing`);\n return true;\n }\n return false;\n });\n\n if (hasMissingRequiredComponent) {\n return false;\n }\n\n if (!projectId.match(/^\\d+$/)) {\n debug.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`);\n return false;\n }\n\n if (!isValidProtocol(protocol)) {\n debug.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`);\n return false;\n }\n\n if (port && isNaN(parseInt(port, 10))) {\n debug.error(`Invalid Sentry Dsn: Invalid port ${port}`);\n return false;\n }\n\n return true;\n}\n\n/**\n * Extract the org ID from a DSN host.\n *\n * @param host The host from a DSN\n * @returns The org ID if found, undefined otherwise\n */\nfunction extractOrgIdFromDsnHost(host) {\n const match = host.match(ORG_ID_REGEX);\n\n return match?.[1];\n}\n\n/**\n * Returns the organization ID of the client.\n *\n * The organization ID is extracted from the DSN. If the client options include a `orgId`, this will always take precedence.\n */\nfunction extractOrgIdFromClient(client) {\n const options = client.getOptions();\n\n const { host } = client.getDsn() || {};\n\n let org_id;\n\n if (options.orgId) {\n org_id = String(options.orgId);\n } else if (host) {\n org_id = extractOrgIdFromDsnHost(host);\n }\n\n return org_id;\n}\n\n/**\n * Creates a valid Sentry Dsn object, identifying a Sentry instance and project.\n * @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source\n */\nfunction makeDsn(from) {\n const components = typeof from === 'string' ? dsnFromString(from) : dsnFromComponents(from);\n if (!components || !validateDsn(components)) {\n return undefined;\n }\n return components;\n}\n\nexport { dsnFromString, dsnToString, extractOrgIdFromClient, extractOrgIdFromDsnHost, makeDsn };\n//# sourceMappingURL=dsn.js.map\n","import { getAsyncContextStrategy } from '../asyncContext/index.js';\nimport { getMainCarrier } from '../carrier.js';\nimport { getCurrentScope } from '../currentScopes.js';\nimport { SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN, SEMANTIC_ATTRIBUTE_SENTRY_OP, SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME, SEMANTIC_ATTRIBUTE_SENTRY_SOURCE } from '../semanticAttributes.js';\nimport { SPAN_STATUS_UNSET, SPAN_STATUS_OK } from '../tracing/spanstatus.js';\nimport { getCapturedScopesOnSpan } from '../tracing/utils.js';\nimport { addNonEnumerableProperty } from './object.js';\nimport { generateSpanId } from './propagationContext.js';\nimport { timestampInSeconds } from './time.js';\nimport { generateSentryTraceHeader, generateTraceparentHeader } from './tracing.js';\nimport { consoleSandbox } from './debug-logger.js';\nimport { _getSpanForScope } from './spanOnScope.js';\n\n// These are aligned with OpenTelemetry trace flags\nconst TRACE_FLAG_NONE = 0x0;\nconst TRACE_FLAG_SAMPLED = 0x1;\n\nlet hasShownSpanDropWarning = false;\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in an event.\n * By default, this will only include trace_id, span_id & parent_span_id.\n * If `includeAllData` is true, it will also include data, op, status & origin.\n */\nfunction spanToTransactionTraceContext(span) {\n const { spanId: span_id, traceId: trace_id } = span.spanContext();\n const { data, op, parent_span_id, status, origin, links } = spanToJSON(span);\n\n return {\n parent_span_id,\n span_id,\n trace_id,\n data,\n op,\n status,\n origin,\n links,\n };\n}\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in a non-transaction event.\n */\nfunction spanToTraceContext(span) {\n const { spanId, traceId: trace_id, isRemote } = span.spanContext();\n\n // If the span is remote, we use a random/virtual span as span_id to the trace context,\n // and the remote span as parent_span_id\n const parent_span_id = isRemote ? spanId : spanToJSON(span).parent_span_id;\n const scope = getCapturedScopesOnSpan(span).scope;\n\n const span_id = isRemote ? scope?.getPropagationContext().propagationSpanId || generateSpanId() : spanId;\n\n return {\n parent_span_id,\n span_id,\n trace_id,\n };\n}\n\n/**\n * Convert a Span to a Sentry trace header.\n */\nfunction spanToTraceHeader(span) {\n const { traceId, spanId } = span.spanContext();\n const sampled = spanIsSampled(span);\n return generateSentryTraceHeader(traceId, spanId, sampled);\n}\n\n/**\n * Convert a Span to a W3C traceparent header.\n */\nfunction spanToTraceparentHeader(span) {\n const { traceId, spanId } = span.spanContext();\n const sampled = spanIsSampled(span);\n return generateTraceparentHeader(traceId, spanId, sampled);\n}\n\n/**\n * Converts the span links array to a flattened version to be sent within an envelope.\n *\n * If the links array is empty, it returns `undefined` so the empty value can be dropped before it's sent.\n */\nfunction convertSpanLinksForEnvelope(links) {\n if (links && links.length > 0) {\n return links.map(({ context: { spanId, traceId, traceFlags, ...restContext }, attributes }) => ({\n span_id: spanId,\n trace_id: traceId,\n sampled: traceFlags === TRACE_FLAG_SAMPLED,\n attributes,\n ...restContext,\n }));\n } else {\n return undefined;\n }\n}\n\n/**\n * Convert a span time input into a timestamp in seconds.\n */\nfunction spanTimeInputToSeconds(input) {\n if (typeof input === 'number') {\n return ensureTimestampInSeconds(input);\n }\n\n if (Array.isArray(input)) {\n // See {@link HrTime} for the array-based time format\n return input[0] + input[1] / 1e9;\n }\n\n if (input instanceof Date) {\n return ensureTimestampInSeconds(input.getTime());\n }\n\n return timestampInSeconds();\n}\n\n/**\n * Converts a timestamp to second, if it was in milliseconds, or keeps it as second.\n */\nfunction ensureTimestampInSeconds(timestamp) {\n const isMs = timestamp > 9999999999;\n return isMs ? timestamp / 1000 : timestamp;\n}\n\n/**\n * Convert a span to a JSON representation.\n */\n// Note: Because of this, we currently have a circular type dependency (which we opted out of in package.json).\n// This is not avoidable as we need `spanToJSON` in `spanUtils.ts`, which in turn is needed by `span.ts` for backwards compatibility.\n// And `spanToJSON` needs the Span class from `span.ts` to check here.\nfunction spanToJSON(span) {\n if (spanIsSentrySpan(span)) {\n return span.getSpanJSON();\n }\n\n const { spanId: span_id, traceId: trace_id } = span.spanContext();\n\n // Handle a span from @opentelemetry/sdk-base-trace's `Span` class\n if (spanIsOpenTelemetrySdkTraceBaseSpan(span)) {\n const { attributes, startTime, name, endTime, status, links } = span;\n\n // In preparation for the next major of OpenTelemetry, we want to support\n // looking up the parent span id according to the new API\n // In OTel v1, the parent span id is accessed as `parentSpanId`\n // In OTel v2, the parent span id is accessed as `spanId` on the `parentSpanContext`\n const parentSpanId =\n 'parentSpanId' in span\n ? span.parentSpanId\n : 'parentSpanContext' in span\n ? (span.parentSpanContext )?.spanId\n : undefined;\n\n return {\n span_id,\n trace_id,\n data: attributes,\n description: name,\n parent_span_id: parentSpanId,\n start_timestamp: spanTimeInputToSeconds(startTime),\n // This is [0,0] by default in OTEL, in which case we want to interpret this as no end time\n timestamp: spanTimeInputToSeconds(endTime) || undefined,\n status: getStatusMessage(status),\n op: attributes[SEMANTIC_ATTRIBUTE_SENTRY_OP],\n origin: attributes[SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN] ,\n links: convertSpanLinksForEnvelope(links),\n };\n }\n\n // Finally, at least we have `spanContext()`....\n // This should not actually happen in reality, but we need to handle it for type safety.\n return {\n span_id,\n trace_id,\n start_timestamp: 0,\n data: {},\n };\n}\n\nfunction spanIsOpenTelemetrySdkTraceBaseSpan(span) {\n const castSpan = span ;\n return !!castSpan.attributes && !!castSpan.startTime && !!castSpan.name && !!castSpan.endTime && !!castSpan.status;\n}\n\n/** Exported only for tests. */\n\n/**\n * Sadly, due to circular dependency checks we cannot actually import the Span class here and check for instanceof.\n * :( So instead we approximate this by checking if it has the `getSpanJSON` method.\n */\nfunction spanIsSentrySpan(span) {\n return typeof (span ).getSpanJSON === 'function';\n}\n\n/**\n * Returns true if a span is sampled.\n * In most cases, you should just use `span.isRecording()` instead.\n * However, this has a slightly different semantic, as it also returns false if the span is finished.\n * So in the case where this distinction is important, use this method.\n */\nfunction spanIsSampled(span) {\n // We align our trace flags with the ones OpenTelemetry use\n // So we also check for sampled the same way they do.\n const { traceFlags } = span.spanContext();\n return traceFlags === TRACE_FLAG_SAMPLED;\n}\n\n/** Get the status message to use for a JSON representation of a span. */\nfunction getStatusMessage(status) {\n if (!status || status.code === SPAN_STATUS_UNSET) {\n return undefined;\n }\n\n if (status.code === SPAN_STATUS_OK) {\n return 'ok';\n }\n\n return status.message || 'unknown_error';\n}\n\nconst CHILD_SPANS_FIELD = '_sentryChildSpans';\nconst ROOT_SPAN_FIELD = '_sentryRootSpan';\n\n/**\n * Adds an opaque child span reference to a span.\n */\nfunction addChildSpanToSpan(span, childSpan) {\n // We store the root span reference on the child span\n // We need this for `getRootSpan()` to work\n const rootSpan = span[ROOT_SPAN_FIELD] || span;\n addNonEnumerableProperty(childSpan , ROOT_SPAN_FIELD, rootSpan);\n\n // We store a list of child spans on the parent span\n // We need this for `getSpanDescendants()` to work\n if (span[CHILD_SPANS_FIELD]) {\n span[CHILD_SPANS_FIELD].add(childSpan);\n } else {\n addNonEnumerableProperty(span, CHILD_SPANS_FIELD, new Set([childSpan]));\n }\n}\n\n/** This is only used internally by Idle Spans. */\nfunction removeChildSpanFromSpan(span, childSpan) {\n if (span[CHILD_SPANS_FIELD]) {\n span[CHILD_SPANS_FIELD].delete(childSpan);\n }\n}\n\n/**\n * Returns an array of the given span and all of its descendants.\n */\nfunction getSpanDescendants(span) {\n const resultSet = new Set();\n\n function addSpanChildren(span) {\n // This exit condition is required to not infinitely loop in case of a circular dependency.\n if (resultSet.has(span)) {\n return;\n // We want to ignore unsampled spans (e.g. non recording spans)\n } else if (spanIsSampled(span)) {\n resultSet.add(span);\n const childSpans = span[CHILD_SPANS_FIELD] ? Array.from(span[CHILD_SPANS_FIELD]) : [];\n for (const childSpan of childSpans) {\n addSpanChildren(childSpan);\n }\n }\n }\n\n addSpanChildren(span);\n\n return Array.from(resultSet);\n}\n\n/**\n * Returns the root span of a given span.\n */\nfunction getRootSpan(span) {\n return span[ROOT_SPAN_FIELD] || span;\n}\n\n/**\n * Returns the currently active span.\n */\nfunction getActiveSpan() {\n const carrier = getMainCarrier();\n const acs = getAsyncContextStrategy(carrier);\n if (acs.getActiveSpan) {\n return acs.getActiveSpan();\n }\n\n return _getSpanForScope(getCurrentScope());\n}\n\n/**\n * Logs a warning once if `beforeSendSpan` is used to drop spans.\n */\nfunction showSpanDropWarning() {\n if (!hasShownSpanDropWarning) {\n consoleSandbox(() => {\n // eslint-disable-next-line no-console\n console.warn(\n '[Sentry] Returning null from `beforeSendSpan` is disallowed. To drop certain spans, configure the respective integrations directly or use `ignoreSpans`.',\n );\n });\n hasShownSpanDropWarning = true;\n }\n}\n\n/**\n * Updates the name of the given span and ensures that the span name is not\n * overwritten by the Sentry SDK.\n *\n * Use this function instead of `span.updateName()` if you want to make sure that\n * your name is kept. For some spans, for example root `http.server` spans the\n * Sentry SDK would otherwise overwrite the span name with a high-quality name\n * it infers when the span ends.\n *\n * Use this function in server code or when your span is started on the server\n * and on the client (browser). If you only update a span name on the client,\n * you can also use `span.updateName()` the SDK does not overwrite the name.\n *\n * @param span - The span to update the name of.\n * @param name - The name to set on the span.\n */\nfunction updateSpanName(span, name) {\n span.updateName(name);\n span.setAttributes({\n [SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'custom',\n [SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME]: name,\n });\n}\n\nexport { TRACE_FLAG_NONE, TRACE_FLAG_SAMPLED, addChildSpanToSpan, convertSpanLinksForEnvelope, getActiveSpan, getRootSpan, getSpanDescendants, getStatusMessage, removeChildSpanFromSpan, showSpanDropWarning, spanIsSampled, spanTimeInputToSeconds, spanToJSON, spanToTraceContext, spanToTraceHeader, spanToTraceparentHeader, spanToTransactionTraceContext, updateSpanName };\n//# sourceMappingURL=spanUtils.js.map\n","import { getClient } from '../currentScopes.js';\n\n// Treeshakable guard to remove all code related to tracing\n\n/**\n * Determines if span recording is currently enabled.\n *\n * Spans are recorded when at least one of `tracesSampleRate` and `tracesSampler`\n * is defined in the SDK config. This function does not make any assumption about\n * sampling decisions, it only checks if the SDK is configured to record spans.\n *\n * Important: This function only determines if span recording is enabled. Trace\n * continuation and propagation is separately controlled and not covered by this function.\n * If this function returns `false`, traces can still be propagated (which is what\n * we refer to by \"Tracing without Performance\")\n * @see https://develop.sentry.dev/sdk/telemetry/traces/tracing-without-performance/\n *\n * @param maybeOptions An SDK options object to be passed to this function.\n * If this option is not provided, the function will use the current client's options.\n */\nfunction hasSpansEnabled(\n maybeOptions,\n) {\n if (typeof __SENTRY_TRACING__ === 'boolean' && !__SENTRY_TRACING__) {\n return false;\n }\n\n const options = maybeOptions || getClient()?.getOptions();\n return (\n !!options &&\n // Note: This check is `!= null`, meaning \"nullish\". `0` is not \"nullish\", `undefined` and `null` are. (This comment was brought to you by 15 minutes of questioning life)\n (options.tracesSampleRate != null || !!options.tracesSampler)\n );\n}\n\nexport { hasSpansEnabled };\n//# sourceMappingURL=hasSpansEnabled.js.map\n","const DEFAULT_ENVIRONMENT = 'production';\n\nexport { DEFAULT_ENVIRONMENT };\n//# sourceMappingURL=constants.js.map\n","import { DEFAULT_ENVIRONMENT } from '../constants.js';\nimport { getClient } from '../currentScopes.js';\nimport { SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE, SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE, SEMANTIC_ATTRIBUTE_SENTRY_SOURCE } from '../semanticAttributes.js';\nimport { baggageHeaderToDynamicSamplingContext, dynamicSamplingContextToSentryBaggageHeader } from '../utils/baggage.js';\nimport { extractOrgIdFromClient } from '../utils/dsn.js';\nimport { hasSpansEnabled } from '../utils/hasSpansEnabled.js';\nimport { addNonEnumerableProperty } from '../utils/object.js';\nimport { getRootSpan, spanToJSON, spanIsSampled } from '../utils/spanUtils.js';\nimport { getCapturedScopesOnSpan } from './utils.js';\n\n/**\n * If you change this value, also update the terser plugin config to\n * avoid minification of the object property!\n */\nconst FROZEN_DSC_FIELD = '_frozenDsc';\n\n/**\n * Freeze the given DSC on the given span.\n */\nfunction freezeDscOnSpan(span, dsc) {\n const spanWithMaybeDsc = span ;\n addNonEnumerableProperty(spanWithMaybeDsc, FROZEN_DSC_FIELD, dsc);\n}\n\n/**\n * Creates a dynamic sampling context from a client.\n *\n * Dispatches the `createDsc` lifecycle hook as a side effect.\n */\nfunction getDynamicSamplingContextFromClient(trace_id, client) {\n const options = client.getOptions();\n\n const { publicKey: public_key } = client.getDsn() || {};\n\n // Instead of conditionally adding non-undefined values, we add them and then remove them if needed\n // otherwise, the order of baggage entries changes, which \"breaks\" a bunch of tests etc.\n const dsc = {\n environment: options.environment || DEFAULT_ENVIRONMENT,\n release: options.release,\n public_key,\n trace_id,\n org_id: extractOrgIdFromClient(client),\n };\n\n client.emit('createDsc', dsc);\n\n return dsc;\n}\n\n/**\n * Get the dynamic sampling context for the currently active scopes.\n */\nfunction getDynamicSamplingContextFromScope(client, scope) {\n const propagationContext = scope.getPropagationContext();\n return propagationContext.dsc || getDynamicSamplingContextFromClient(propagationContext.traceId, client);\n}\n\n/**\n * Creates a dynamic sampling context from a span (and client and scope)\n *\n * @param span the span from which a few values like the root span name and sample rate are extracted.\n *\n * @returns a dynamic sampling context\n */\nfunction getDynamicSamplingContextFromSpan(span) {\n const client = getClient();\n if (!client) {\n return {};\n }\n\n const rootSpan = getRootSpan(span);\n const rootSpanJson = spanToJSON(rootSpan);\n const rootSpanAttributes = rootSpanJson.data;\n const traceState = rootSpan.spanContext().traceState;\n\n // The span sample rate that was locally applied to the root span should also always be applied to the DSC, even if the DSC is frozen.\n // This is so that the downstream traces/services can use parentSampleRate in their `tracesSampler` to make consistent sampling decisions across the entire trace.\n const rootSpanSampleRate =\n traceState?.get('sentry.sample_rate') ??\n rootSpanAttributes[SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE] ??\n rootSpanAttributes[SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE];\n\n function applyLocalSampleRateToDsc(dsc) {\n if (typeof rootSpanSampleRate === 'number' || typeof rootSpanSampleRate === 'string') {\n dsc.sample_rate = `${rootSpanSampleRate}`;\n }\n return dsc;\n }\n\n // For core implementation, we freeze the DSC onto the span as a non-enumerable property\n const frozenDsc = (rootSpan )[FROZEN_DSC_FIELD];\n if (frozenDsc) {\n return applyLocalSampleRateToDsc(frozenDsc);\n }\n\n // For OpenTelemetry, we freeze the DSC on the trace state\n const traceStateDsc = traceState?.get('sentry.dsc');\n\n // If the span has a DSC, we want it to take precedence\n const dscOnTraceState = traceStateDsc && baggageHeaderToDynamicSamplingContext(traceStateDsc);\n\n if (dscOnTraceState) {\n return applyLocalSampleRateToDsc(dscOnTraceState);\n }\n\n // Else, we generate it from the span\n const dsc = getDynamicSamplingContextFromClient(span.spanContext().traceId, client);\n\n // We don't want to have a transaction name in the DSC if the source is \"url\" because URLs might contain PII\n const source = rootSpanAttributes[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n\n // after JSON conversion, txn.name becomes jsonSpan.description\n const name = rootSpanJson.description;\n if (source !== 'url' && name) {\n dsc.transaction = name;\n }\n\n // How can we even land here with hasSpansEnabled() returning false?\n // Otel creates a Non-recording span in Tracing Without Performance mode when handling incoming requests\n // So we end up with an active span that is not sampled (neither positively nor negatively)\n if (hasSpansEnabled()) {\n dsc.sampled = String(spanIsSampled(rootSpan));\n dsc.sample_rand =\n // In OTEL we store the sample rand on the trace state because we cannot access scopes for NonRecordingSpans\n // The Sentry OTEL SpanSampler takes care of writing the sample rand on the root span\n traceState?.get('sentry.sample_rand') ??\n // On all other platforms we can actually get the scopes from a root span (we use this as a fallback)\n getCapturedScopesOnSpan(rootSpan).scope?.getPropagationContext().sampleRand.toString();\n }\n\n applyLocalSampleRateToDsc(dsc);\n\n client.emit('createDsc', dsc, rootSpan);\n\n return dsc;\n}\n\n/**\n * Convert a Span to a baggage header.\n */\nfunction spanToBaggageHeader(span) {\n const dsc = getDynamicSamplingContextFromSpan(span);\n return dynamicSamplingContextToSentryBaggageHeader(dsc);\n}\n\nexport { freezeDscOnSpan, getDynamicSamplingContextFromClient, getDynamicSamplingContextFromScope, getDynamicSamplingContextFromSpan, spanToBaggageHeader };\n//# sourceMappingURL=dynamicSamplingContext.js.map\n","import { isVueViewModel, isSyntheticEvent } from './is.js';\nimport { convertToPlainObject } from './object.js';\nimport { getFunctionName } from './stacktrace.js';\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normalized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction normalize(input, depth = 100, maxProperties = +Infinity) {\n try {\n // since we're at the outermost level, we don't provide a key\n return visit('', input, depth, maxProperties);\n } catch (err) {\n return { ERROR: `**non-serializable** (${err})` };\n }\n}\n\n/** JSDoc */\nfunction normalizeToSize(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n object,\n // Default Node.js REPL depth\n depth = 3,\n // 100kB, as 200kB is max payload size, so half sounds reasonable\n maxSize = 100 * 1024,\n) {\n const normalized = normalize(object, depth);\n\n if (jsonSize(normalized) > maxSize) {\n return normalizeToSize(object, depth - 1, maxSize);\n }\n\n return normalized ;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n key,\n value,\n depth = +Infinity,\n maxProperties = +Infinity,\n memo = memoBuilder(),\n) {\n const [memoize, unmemoize] = memo;\n\n // Get the simple cases out of the way first\n if (\n value == null || // this matches null and undefined -> eqeq not eqeqeq\n ['boolean', 'string'].includes(typeof value) ||\n (typeof value === 'number' && Number.isFinite(value))\n ) {\n return value ;\n }\n\n const stringified = stringifyValue(key, value);\n\n // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n if (!stringified.startsWith('[object ')) {\n return stringified;\n }\n\n // From here on, we can assert that `value` is either an object or an array.\n\n // Do not normalize objects that we know have already been normalized. As a general rule, the\n // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n // have already been normalized.\n if ((value )['__sentry_skip_normalization__']) {\n return value ;\n }\n\n // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n // We keep a certain amount of depth.\n // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n const remainingDepth =\n typeof (value )['__sentry_override_normalization_depth__'] === 'number'\n ? ((value )['__sentry_override_normalization_depth__'] )\n : depth;\n\n // We're also done if we've reached the max depth\n if (remainingDepth === 0) {\n // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n return stringified.replace('object ', '');\n }\n\n // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n if (memoize(value)) {\n return '[Circular ~]';\n }\n\n // If the value has a `toJSON` method, we call it to extract more information\n const valueWithToJSON = value ;\n if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n try {\n const jsonValue = valueWithToJSON.toJSON();\n // We need to normalize the return value of `.toJSON()` in case it has circular references\n return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n } catch {\n // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n }\n }\n\n // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n // property/entry, and keep track of the number of items we add to it.\n const normalized = (Array.isArray(value) ? [] : {}) ;\n let numAdded = 0;\n\n // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n // properties are non-enumerable and otherwise would get missed.\n const visitable = convertToPlainObject(value );\n\n for (const visitKey in visitable) {\n // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n continue;\n }\n\n if (numAdded >= maxProperties) {\n normalized[visitKey] = '[MaxProperties ~]';\n break;\n }\n\n // Recursively visit all the child nodes\n const visitValue = visitable[visitKey];\n normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n numAdded++;\n }\n\n // Once we've visited all the branches, remove the parent from memo storage\n unmemoize(value);\n\n // Return accumulated values\n return normalized;\n}\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n key,\n // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n // our internal use, it'll do\n value,\n) {\n try {\n if (key === 'domain' && value && typeof value === 'object' && (value )._events) {\n return '[Domain]';\n }\n\n if (key === 'domainEmitter') {\n return '[DomainEmitter]';\n }\n\n // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n // which won't throw if they are not present.\n\n if (typeof global !== 'undefined' && value === global) {\n return '[Global]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof window !== 'undefined' && value === window) {\n return '[Window]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof document !== 'undefined' && value === document) {\n return '[Document]';\n }\n\n if (isVueViewModel(value)) {\n return '[VueViewModel]';\n }\n\n // React's SyntheticEvent thingy\n if (isSyntheticEvent(value)) {\n return '[SyntheticEvent]';\n }\n\n if (typeof value === 'number' && !Number.isFinite(value)) {\n return `[${value}]`;\n }\n\n if (typeof value === 'function') {\n return `[Function: ${getFunctionName(value)}]`;\n }\n\n if (typeof value === 'symbol') {\n return `[${String(value)}]`;\n }\n\n // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n if (typeof value === 'bigint') {\n return `[BigInt: ${String(value)}]`;\n }\n\n // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n // we can make sure that only plain objects come out that way.\n const objName = getConstructorName(value);\n\n // Handle HTML Elements\n if (/^HTML(\\w*)Element$/.test(objName)) {\n return `[HTMLElement: ${objName}]`;\n }\n\n return `[object ${objName}]`;\n } catch (err) {\n return `**non-serializable** (${err})`;\n }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value) {\n const prototype = Object.getPrototypeOf(value);\n\n return prototype?.constructor ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value) {\n // eslint-disable-next-line no-bitwise\n return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value) {\n return utf8Length(JSON.stringify(value));\n}\n\n/**\n * Normalizes URLs in exceptions and stacktraces to a base path so Sentry can fingerprint\n * across platforms and working directory.\n *\n * @param url The URL to be normalized.\n * @param basePath The application base path.\n * @returns The normalized URL.\n */\nfunction normalizeUrlToBase(url, basePath) {\n const escapedBase = basePath\n // Backslash to forward\n .replace(/\\\\/g, '/')\n // Escape RegExp special characters\n .replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n\n let newUrl = url;\n try {\n newUrl = decodeURI(url);\n } catch {\n // Sometime this breaks\n }\n return (\n newUrl\n .replace(/\\\\/g, '/')\n .replace(/webpack:\\/?/g, '') // Remove intermediate base path\n // eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor\n .replace(new RegExp(`(file://)?/*${escapedBase}/*`, 'ig'), 'app:///')\n );\n}\n\n/**\n * Helper to decycle json objects\n */\nfunction memoBuilder() {\n const inner = new WeakSet();\n function memoize(obj) {\n if (inner.has(obj)) {\n return true;\n }\n inner.add(obj);\n return false;\n }\n\n function unmemoize(obj) {\n inner.delete(obj);\n }\n return [memoize, unmemoize];\n}\n\nexport { normalize, normalizeToSize, normalizeUrlToBase };\n//# sourceMappingURL=normalize.js.map\n","import { isThenable } from './is.js';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/** SyncPromise internal states */\nconst STATE_PENDING = 0;\nconst STATE_RESOLVED = 1;\nconst STATE_REJECTED = 2;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nfunction resolvedSyncPromise(value) {\n return new SyncPromise(resolve => {\n resolve(value);\n });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nfunction rejectedSyncPromise(reason) {\n return new SyncPromise((_, reject) => {\n reject(reason);\n });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise {\n\n constructor(executor) {\n this._state = STATE_PENDING;\n this._handlers = [];\n\n this._runExecutor(executor);\n }\n\n /** @inheritdoc */\n then(\n onfulfilled,\n onrejected,\n ) {\n return new SyncPromise((resolve, reject) => {\n this._handlers.push([\n false,\n result => {\n if (!onfulfilled) {\n // TODO: ¯\\_(ツ)_/¯\n // TODO: FIXME\n resolve(result );\n } else {\n try {\n resolve(onfulfilled(result));\n } catch (e) {\n reject(e);\n }\n }\n },\n reason => {\n if (!onrejected) {\n reject(reason);\n } else {\n try {\n resolve(onrejected(reason));\n } catch (e) {\n reject(e);\n }\n }\n },\n ]);\n this._executeHandlers();\n });\n }\n\n /** @inheritdoc */\n catch(\n onrejected,\n ) {\n return this.then(val => val, onrejected);\n }\n\n /** @inheritdoc */\n finally(onfinally) {\n return new SyncPromise((resolve, reject) => {\n let val;\n let isRejected;\n\n return this.then(\n value => {\n isRejected = false;\n val = value;\n if (onfinally) {\n onfinally();\n }\n },\n reason => {\n isRejected = true;\n val = reason;\n if (onfinally) {\n onfinally();\n }\n },\n ).then(() => {\n if (isRejected) {\n reject(val);\n return;\n }\n\n resolve(val );\n });\n });\n }\n\n /** Excute the resolve/reject handlers. */\n _executeHandlers() {\n if (this._state === STATE_PENDING) {\n return;\n }\n\n const cachedHandlers = this._handlers.slice();\n this._handlers = [];\n\n cachedHandlers.forEach(handler => {\n if (handler[0]) {\n return;\n }\n\n if (this._state === STATE_RESOLVED) {\n handler[1](this._value );\n }\n\n if (this._state === STATE_REJECTED) {\n handler[2](this._value);\n }\n\n handler[0] = true;\n });\n }\n\n /** Run the executor for the SyncPromise. */\n _runExecutor(executor) {\n const setResult = (state, value) => {\n if (this._state !== STATE_PENDING) {\n return;\n }\n\n if (isThenable(value)) {\n void (value ).then(resolve, reject);\n return;\n }\n\n this._state = state;\n this._value = value;\n\n this._executeHandlers();\n };\n\n const resolve = (value) => {\n setResult(STATE_RESOLVED, value);\n };\n\n const reject = (reason) => {\n setResult(STATE_REJECTED, reason);\n };\n\n try {\n executor(resolve, reject);\n } catch (e) {\n reject(e);\n }\n }\n}\n\nexport { SyncPromise, rejectedSyncPromise, resolvedSyncPromise };\n//# sourceMappingURL=syncpromise.js.map\n","import { DEBUG_BUILD } from './debug-build.js';\nimport { debug } from './utils/debug-logger.js';\nimport { isThenable } from './utils/is.js';\nimport { resolvedSyncPromise, rejectedSyncPromise } from './utils/syncpromise.js';\n\n/**\n * Process an array of event processors, returning the processed event (or `null` if the event was dropped).\n */\nfunction notifyEventProcessors(\n processors,\n event,\n hint,\n index = 0,\n) {\n try {\n const result = _notifyEventProcessors(event, hint, processors, index);\n return isThenable(result) ? result : resolvedSyncPromise(result);\n } catch (error) {\n return rejectedSyncPromise(error);\n }\n}\n\nfunction _notifyEventProcessors(\n event,\n hint,\n processors,\n index,\n) {\n const processor = processors[index];\n\n if (!event || !processor) {\n return event;\n }\n\n const result = processor({ ...event }, hint);\n\n DEBUG_BUILD && result === null && debug.log(`Event processor \"${processor.id || '?'}\" dropped event`);\n\n if (isThenable(result)) {\n return result.then(final => _notifyEventProcessors(final, hint, processors, index + 1));\n }\n\n return _notifyEventProcessors(result, hint, processors, index + 1);\n}\n\nexport { notifyEventProcessors };\n//# sourceMappingURL=eventProcessors.js.map\n","import { getDynamicSamplingContextFromSpan } from '../tracing/dynamicSamplingContext.js';\nimport { merge } from './merge.js';\nimport { spanToTraceContext, getRootSpan, spanToJSON } from './spanUtils.js';\n\n/**\n * Applies data from the scope to the event and runs all event processors on it.\n */\nfunction applyScopeDataToEvent(event, data) {\n const { fingerprint, span, breadcrumbs, sdkProcessingMetadata } = data;\n\n // Apply general data\n applyDataToEvent(event, data);\n\n // We want to set the trace context for normal events only if there isn't already\n // a trace context on the event. There is a product feature in place where we link\n // errors with transaction and it relies on that.\n if (span) {\n applySpanToEvent(event, span);\n }\n\n applyFingerprintToEvent(event, fingerprint);\n applyBreadcrumbsToEvent(event, breadcrumbs);\n applySdkMetadataToEvent(event, sdkProcessingMetadata);\n}\n\n/** Merge data of two scopes together. */\nfunction mergeScopeData(data, mergeData) {\n const {\n extra,\n tags,\n user,\n contexts,\n level,\n sdkProcessingMetadata,\n breadcrumbs,\n fingerprint,\n eventProcessors,\n attachments,\n propagationContext,\n transactionName,\n span,\n } = mergeData;\n\n mergeAndOverwriteScopeData(data, 'extra', extra);\n mergeAndOverwriteScopeData(data, 'tags', tags);\n mergeAndOverwriteScopeData(data, 'user', user);\n mergeAndOverwriteScopeData(data, 'contexts', contexts);\n\n data.sdkProcessingMetadata = merge(data.sdkProcessingMetadata, sdkProcessingMetadata, 2);\n\n if (level) {\n data.level = level;\n }\n\n if (transactionName) {\n data.transactionName = transactionName;\n }\n\n if (span) {\n data.span = span;\n }\n\n if (breadcrumbs.length) {\n data.breadcrumbs = [...data.breadcrumbs, ...breadcrumbs];\n }\n\n if (fingerprint.length) {\n data.fingerprint = [...data.fingerprint, ...fingerprint];\n }\n\n if (eventProcessors.length) {\n data.eventProcessors = [...data.eventProcessors, ...eventProcessors];\n }\n\n if (attachments.length) {\n data.attachments = [...data.attachments, ...attachments];\n }\n\n data.propagationContext = { ...data.propagationContext, ...propagationContext };\n}\n\n/**\n * Merges certain scope data. Undefined values will overwrite any existing values.\n * Exported only for tests.\n */\nfunction mergeAndOverwriteScopeData\n\n(data, prop, mergeVal) {\n data[prop] = merge(data[prop], mergeVal, 1);\n}\n\nfunction applyDataToEvent(event, data) {\n const { extra, tags, user, contexts, level, transactionName } = data;\n\n if (Object.keys(extra).length) {\n event.extra = { ...extra, ...event.extra };\n }\n\n if (Object.keys(tags).length) {\n event.tags = { ...tags, ...event.tags };\n }\n\n if (Object.keys(user).length) {\n event.user = { ...user, ...event.user };\n }\n\n if (Object.keys(contexts).length) {\n event.contexts = { ...contexts, ...event.contexts };\n }\n\n if (level) {\n event.level = level;\n }\n\n // transaction events get their `transaction` from the root span name\n if (transactionName && event.type !== 'transaction') {\n event.transaction = transactionName;\n }\n}\n\nfunction applyBreadcrumbsToEvent(event, breadcrumbs) {\n const mergedBreadcrumbs = [...(event.breadcrumbs || []), ...breadcrumbs];\n event.breadcrumbs = mergedBreadcrumbs.length ? mergedBreadcrumbs : undefined;\n}\n\nfunction applySdkMetadataToEvent(event, sdkProcessingMetadata) {\n event.sdkProcessingMetadata = {\n ...event.sdkProcessingMetadata,\n ...sdkProcessingMetadata,\n };\n}\n\nfunction applySpanToEvent(event, span) {\n event.contexts = {\n trace: spanToTraceContext(span),\n ...event.contexts,\n };\n\n event.sdkProcessingMetadata = {\n dynamicSamplingContext: getDynamicSamplingContextFromSpan(span),\n ...event.sdkProcessingMetadata,\n };\n\n const rootSpan = getRootSpan(span);\n const transactionName = spanToJSON(rootSpan).description;\n if (transactionName && !event.transaction && event.type === 'transaction') {\n event.transaction = transactionName;\n }\n}\n\n/**\n * Applies fingerprint from the scope to the event if there's one,\n * uses message if there's one instead or get rid of empty fingerprint\n */\nfunction applyFingerprintToEvent(event, fingerprint) {\n // Make sure it's an array first and we actually have something in place\n event.fingerprint = event.fingerprint\n ? Array.isArray(event.fingerprint)\n ? event.fingerprint\n : [event.fingerprint]\n : [];\n\n // If we have something on the scope, then merge it with event\n if (fingerprint) {\n event.fingerprint = event.fingerprint.concat(fingerprint);\n }\n\n // If we have no data at all, remove empty array default\n if (!event.fingerprint.length) {\n delete event.fingerprint;\n }\n}\n\nexport { applyScopeDataToEvent, mergeAndOverwriteScopeData, mergeScopeData };\n//# sourceMappingURL=applyScopeDataToEvent.js.map\n","import { GLOBAL_OBJ } from './worldwide.js';\n\nlet parsedStackResults;\nlet lastSentryKeysCount;\nlet lastNativeKeysCount;\nlet cachedFilenameDebugIds;\n\n/**\n * Returns a map of filenames to debug identifiers.\n * Supports both proprietary _sentryDebugIds and native _debugIds (e.g., from Vercel) formats.\n */\nfunction getFilenameToDebugIdMap(stackParser) {\n const sentryDebugIdMap = GLOBAL_OBJ._sentryDebugIds;\n const nativeDebugIdMap = GLOBAL_OBJ._debugIds;\n\n if (!sentryDebugIdMap && !nativeDebugIdMap) {\n return {};\n }\n\n const sentryDebugIdKeys = sentryDebugIdMap ? Object.keys(sentryDebugIdMap) : [];\n const nativeDebugIdKeys = nativeDebugIdMap ? Object.keys(nativeDebugIdMap) : [];\n\n // If the count of registered globals hasn't changed since the last call, we\n // can just return the cached result.\n if (\n cachedFilenameDebugIds &&\n sentryDebugIdKeys.length === lastSentryKeysCount &&\n nativeDebugIdKeys.length === lastNativeKeysCount\n ) {\n return cachedFilenameDebugIds;\n }\n\n lastSentryKeysCount = sentryDebugIdKeys.length;\n lastNativeKeysCount = nativeDebugIdKeys.length;\n\n // Build a map of filename -> debug_id from both sources\n cachedFilenameDebugIds = {};\n\n if (!parsedStackResults) {\n parsedStackResults = {};\n }\n\n const processDebugIds = (debugIdKeys, debugIdMap) => {\n for (const key of debugIdKeys) {\n const debugId = debugIdMap[key];\n const result = parsedStackResults?.[key];\n\n if (result && cachedFilenameDebugIds && debugId) {\n // Use cached filename but update with current debug ID\n cachedFilenameDebugIds[result[0]] = debugId;\n // Update cached result with new debug ID\n if (parsedStackResults) {\n parsedStackResults[key] = [result[0], debugId];\n }\n } else if (debugId) {\n const parsedStack = stackParser(key);\n\n for (let i = parsedStack.length - 1; i >= 0; i--) {\n const stackFrame = parsedStack[i];\n const filename = stackFrame?.filename;\n\n if (filename && cachedFilenameDebugIds && parsedStackResults) {\n cachedFilenameDebugIds[filename] = debugId;\n parsedStackResults[key] = [filename, debugId];\n break;\n }\n }\n }\n }\n };\n\n if (sentryDebugIdMap) {\n processDebugIds(sentryDebugIdKeys, sentryDebugIdMap);\n }\n\n // Native _debugIds will override _sentryDebugIds if same file\n if (nativeDebugIdMap) {\n processDebugIds(nativeDebugIdKeys, nativeDebugIdMap);\n }\n\n return cachedFilenameDebugIds;\n}\n\n/**\n * Returns a list of debug images for the given resources.\n */\nfunction getDebugImagesForResources(\n stackParser,\n resource_paths,\n) {\n const filenameDebugIdMap = getFilenameToDebugIdMap(stackParser);\n\n if (!filenameDebugIdMap) {\n return [];\n }\n\n const images = [];\n for (const path of resource_paths) {\n if (path && filenameDebugIdMap[path]) {\n images.push({\n type: 'sourcemap',\n code_file: path,\n debug_id: filenameDebugIdMap[path],\n });\n }\n }\n\n return images;\n}\n\nexport { getDebugImagesForResources, getFilenameToDebugIdMap };\n//# sourceMappingURL=debug-ids.js.map\n","import { DEFAULT_ENVIRONMENT } from '../constants.js';\nimport { getGlobalScope } from '../currentScopes.js';\nimport { notifyEventProcessors } from '../eventProcessors.js';\nimport { Scope } from '../scope.js';\nimport { mergeScopeData, applyScopeDataToEvent } from './applyScopeDataToEvent.js';\nimport { getFilenameToDebugIdMap } from './debug-ids.js';\nimport { uuid4, addExceptionMechanism } from './misc.js';\nimport { normalize } from './normalize.js';\nimport { truncate } from './string.js';\nimport { dateTimestampInSeconds } from './time.js';\n\n/**\n * This type makes sure that we get either a CaptureContext, OR an EventHint.\n * It does not allow mixing them, which could lead to unexpected outcomes, e.g. this is disallowed:\n * { user: { id: '123' }, mechanism: { handled: false } }\n */\n\n/**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n * @hidden\n */\nfunction prepareEvent(\n options,\n event,\n hint,\n scope,\n client,\n isolationScope,\n) {\n const { normalizeDepth = 3, normalizeMaxBreadth = 1000 } = options;\n const prepared = {\n ...event,\n event_id: event.event_id || hint.event_id || uuid4(),\n timestamp: event.timestamp || dateTimestampInSeconds(),\n };\n const integrations = hint.integrations || options.integrations.map(i => i.name);\n\n applyClientOptions(prepared, options);\n applyIntegrationsMetadata(prepared, integrations);\n\n if (client) {\n client.emit('applyFrameMetadata', event);\n }\n\n // Only put debug IDs onto frames for error events.\n if (event.type === undefined) {\n applyDebugIds(prepared, options.stackParser);\n }\n\n // If we have scope given to us, use it as the base for further modifications.\n // This allows us to prevent unnecessary copying of data if `captureContext` is not provided.\n const finalScope = getFinalScope(scope, hint.captureContext);\n\n if (hint.mechanism) {\n addExceptionMechanism(prepared, hint.mechanism);\n }\n\n const clientEventProcessors = client ? client.getEventProcessors() : [];\n\n // This should be the last thing called, since we want that\n // {@link Scope.addEventProcessor} gets the finished prepared event.\n // Merge scope data together\n const data = getGlobalScope().getScopeData();\n\n if (isolationScope) {\n const isolationData = isolationScope.getScopeData();\n mergeScopeData(data, isolationData);\n }\n\n if (finalScope) {\n const finalScopeData = finalScope.getScopeData();\n mergeScopeData(data, finalScopeData);\n }\n\n const attachments = [...(hint.attachments || []), ...data.attachments];\n if (attachments.length) {\n hint.attachments = attachments;\n }\n\n applyScopeDataToEvent(prepared, data);\n\n const eventProcessors = [\n ...clientEventProcessors,\n // Run scope event processors _after_ all other processors\n ...data.eventProcessors,\n ];\n\n const result = notifyEventProcessors(eventProcessors, prepared, hint);\n\n return result.then(evt => {\n if (evt) {\n // We apply the debug_meta field only after all event processors have ran, so that if any event processors modified\n // file names (e.g.the RewriteFrames integration) the filename -> debug ID relationship isn't destroyed.\n // This should not cause any PII issues, since we're only moving data that is already on the event and not adding\n // any new data\n applyDebugMeta(evt);\n }\n\n if (typeof normalizeDepth === 'number' && normalizeDepth > 0) {\n return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth);\n }\n return evt;\n });\n}\n\n/**\n * Enhances event using the client configuration.\n * It takes care of all \"static\" values like environment, release and `dist`,\n * as well as truncating overly long values.\n *\n * Only exported for tests.\n *\n * @param event event instance to be enhanced\n */\nfunction applyClientOptions(event, options) {\n const { environment, release, dist, maxValueLength = 250 } = options;\n\n // empty strings do not make sense for environment, release, and dist\n // so we handle them the same as if they were not provided\n event.environment = event.environment || environment || DEFAULT_ENVIRONMENT;\n\n if (!event.release && release) {\n event.release = release;\n }\n\n if (!event.dist && dist) {\n event.dist = dist;\n }\n\n const request = event.request;\n if (request?.url) {\n request.url = truncate(request.url, maxValueLength);\n }\n}\n\n/**\n * Puts debug IDs into the stack frames of an error event.\n */\nfunction applyDebugIds(event, stackParser) {\n // Build a map of filename -> debug_id\n const filenameDebugIdMap = getFilenameToDebugIdMap(stackParser);\n\n event.exception?.values?.forEach(exception => {\n exception.stacktrace?.frames?.forEach(frame => {\n if (frame.filename) {\n frame.debug_id = filenameDebugIdMap[frame.filename];\n }\n });\n });\n}\n\n/**\n * Moves debug IDs from the stack frames of an error event into the debug_meta field.\n */\nfunction applyDebugMeta(event) {\n // Extract debug IDs and filenames from the stack frames on the event.\n const filenameDebugIdMap = {};\n event.exception?.values?.forEach(exception => {\n exception.stacktrace?.frames?.forEach(frame => {\n if (frame.debug_id) {\n if (frame.abs_path) {\n filenameDebugIdMap[frame.abs_path] = frame.debug_id;\n } else if (frame.filename) {\n filenameDebugIdMap[frame.filename] = frame.debug_id;\n }\n delete frame.debug_id;\n }\n });\n });\n\n if (Object.keys(filenameDebugIdMap).length === 0) {\n return;\n }\n\n // Fill debug_meta information\n event.debug_meta = event.debug_meta || {};\n event.debug_meta.images = event.debug_meta.images || [];\n const images = event.debug_meta.images;\n Object.entries(filenameDebugIdMap).forEach(([filename, debug_id]) => {\n images.push({\n type: 'sourcemap',\n code_file: filename,\n debug_id,\n });\n });\n}\n\n/**\n * This function adds all used integrations to the SDK info in the event.\n * @param event The event that will be filled with all integrations.\n */\nfunction applyIntegrationsMetadata(event, integrationNames) {\n if (integrationNames.length > 0) {\n event.sdk = event.sdk || {};\n event.sdk.integrations = [...(event.sdk.integrations || []), ...integrationNames];\n }\n}\n\n/**\n * Applies `normalize` function on necessary `Event` attributes to make them safe for serialization.\n * Normalized keys:\n * - `breadcrumbs.data`\n * - `user`\n * - `contexts`\n * - `extra`\n * @param event Event\n * @returns Normalized event\n */\nfunction normalizeEvent(event, depth, maxBreadth) {\n if (!event) {\n return null;\n }\n\n const normalized = {\n ...event,\n ...(event.breadcrumbs && {\n breadcrumbs: event.breadcrumbs.map(b => ({\n ...b,\n ...(b.data && {\n data: normalize(b.data, depth, maxBreadth),\n }),\n })),\n }),\n ...(event.user && {\n user: normalize(event.user, depth, maxBreadth),\n }),\n ...(event.contexts && {\n contexts: normalize(event.contexts, depth, maxBreadth),\n }),\n ...(event.extra && {\n extra: normalize(event.extra, depth, maxBreadth),\n }),\n };\n\n // event.contexts.trace stores information about a Transaction. Similarly,\n // event.spans[] stores information about child Spans. Given that a\n // Transaction is conceptually a Span, normalization should apply to both\n // Transactions and Spans consistently.\n // For now the decision is to skip normalization of Transactions and Spans,\n // so this block overwrites the normalized event to add back the original\n // Transaction information prior to normalization.\n if (event.contexts?.trace && normalized.contexts) {\n normalized.contexts.trace = event.contexts.trace;\n\n // event.contexts.trace.data may contain circular/dangerous data so we need to normalize it\n if (event.contexts.trace.data) {\n normalized.contexts.trace.data = normalize(event.contexts.trace.data, depth, maxBreadth);\n }\n }\n\n // event.spans[].data may contain circular/dangerous data so we need to normalize it\n if (event.spans) {\n normalized.spans = event.spans.map(span => {\n return {\n ...span,\n ...(span.data && {\n data: normalize(span.data, depth, maxBreadth),\n }),\n };\n });\n }\n\n // event.contexts.flags (FeatureFlagContext) stores context for our feature\n // flag integrations. It has a greater nesting depth than our other typed\n // Contexts, so we re-normalize with a fixed depth of 3 here. We do not want\n // to skip this in case of conflicting, user-provided context.\n if (event.contexts?.flags && normalized.contexts) {\n normalized.contexts.flags = normalize(event.contexts.flags, 3, maxBreadth);\n }\n\n return normalized;\n}\n\nfunction getFinalScope(scope, captureContext) {\n if (!captureContext) {\n return scope;\n }\n\n const finalScope = scope ? scope.clone() : new Scope();\n finalScope.update(captureContext);\n return finalScope;\n}\n\n/**\n * Parse either an `EventHint` directly, or convert a `CaptureContext` to an `EventHint`.\n * This is used to allow to update method signatures that used to accept a `CaptureContext` but should now accept an `EventHint`.\n */\nfunction parseEventHintOrCaptureContext(\n hint,\n) {\n if (!hint) {\n return undefined;\n }\n\n // If you pass a Scope or `() => Scope` as CaptureContext, we just return this as captureContext\n if (hintIsScopeOrFunction(hint)) {\n return { captureContext: hint };\n }\n\n if (hintIsScopeContext(hint)) {\n return {\n captureContext: hint,\n };\n }\n\n return hint;\n}\n\nfunction hintIsScopeOrFunction(hint) {\n return hint instanceof Scope || typeof hint === 'function';\n}\n\nconst captureContextKeys = [\n 'user',\n 'level',\n 'extra',\n 'contexts',\n 'tags',\n 'fingerprint',\n 'propagationContext',\n] ;\n\nfunction hintIsScopeContext(hint) {\n return Object.keys(hint).some(key => captureContextKeys.includes(key ));\n}\n\nexport { applyClientOptions, applyDebugIds, applyDebugMeta, parseEventHintOrCaptureContext, prepareEvent };\n//# sourceMappingURL=prepareEvent.js.map\n","import { getCurrentScope, getClient, withIsolationScope, getIsolationScope } from './currentScopes.js';\nimport { DEBUG_BUILD } from './debug-build.js';\nimport { makeSession, updateSession, closeSession } from './session.js';\nimport { debug } from './utils/debug-logger.js';\nimport { isThenable } from './utils/is.js';\nimport { uuid4 } from './utils/misc.js';\nimport { parseEventHintOrCaptureContext } from './utils/prepareEvent.js';\nimport { timestampInSeconds } from './utils/time.js';\nimport { GLOBAL_OBJ } from './utils/worldwide.js';\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception The exception to capture.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured Sentry event.\n */\nfunction captureException(exception, hint) {\n return getCurrentScope().captureException(exception, parseEventHintOrCaptureContext(hint));\n}\n\n/**\n * Captures a message event and sends it to Sentry.\n *\n * @param message The message to send to Sentry.\n * @param captureContext Define the level of the message or pass in additional data to attach to the message.\n * @returns the id of the captured message.\n */\nfunction captureMessage(message, captureContext) {\n // This is necessary to provide explicit scopes upgrade, without changing the original\n // arity of the `captureMessage(message, level)` method.\n const level = typeof captureContext === 'string' ? captureContext : undefined;\n const context = typeof captureContext !== 'string' ? { captureContext } : undefined;\n return getCurrentScope().captureMessage(message, level, context);\n}\n\n/**\n * Captures a manually created event and sends it to Sentry.\n *\n * @param event The event to send to Sentry.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured event.\n */\nfunction captureEvent(event, hint) {\n return getCurrentScope().captureEvent(event, hint);\n}\n\n/**\n * Sets context data with the given name.\n * @param name of the context\n * @param context Any kind of data. This data will be normalized.\n */\nfunction setContext(name, context) {\n getIsolationScope().setContext(name, context);\n}\n\n/**\n * Set an object that will be merged sent as extra data with the event.\n * @param extras Extras object to merge into current context.\n */\nfunction setExtras(extras) {\n getIsolationScope().setExtras(extras);\n}\n\n/**\n * Set key:value that will be sent as extra data with the event.\n * @param key String of extra\n * @param extra Any kind of data. This data will be normalized.\n */\nfunction setExtra(key, extra) {\n getIsolationScope().setExtra(key, extra);\n}\n\n/**\n * Set an object that will be merged sent as tags data with the event.\n * @param tags Tags context object to merge into current context.\n */\nfunction setTags(tags) {\n getIsolationScope().setTags(tags);\n}\n\n/**\n * Set key:value that will be sent as tags data with the event.\n *\n * Can also be used to unset a tag, by passing `undefined`.\n *\n * @param key String key of tag\n * @param value Value of tag\n */\nfunction setTag(key, value) {\n getIsolationScope().setTag(key, value);\n}\n\n/**\n * Updates user context information for future events.\n *\n * @param user User context object to be set in the current context. Pass `null` to unset the user.\n */\nfunction setUser(user) {\n getIsolationScope().setUser(user);\n}\n\n/**\n * The last error event id of the isolation scope.\n *\n * Warning: This function really returns the last recorded error event id on the current\n * isolation scope. If you call this function after handling a certain error and another error\n * is captured in between, the last one is returned instead of the one you might expect.\n * Also, ids of events that were never sent to Sentry (for example because\n * they were dropped in `beforeSend`) could be returned.\n *\n * @returns The last event id of the isolation scope.\n */\nfunction lastEventId() {\n return getIsolationScope().lastEventId();\n}\n\n/**\n * Create a cron monitor check in and send it to Sentry.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction captureCheckIn(checkIn, upsertMonitorConfig) {\n const scope = getCurrentScope();\n const client = getClient();\n if (!client) {\n DEBUG_BUILD && debug.warn('Cannot capture check-in. No client defined.');\n } else if (!client.captureCheckIn) {\n DEBUG_BUILD && debug.warn('Cannot capture check-in. Client does not support sending check-ins.');\n } else {\n return client.captureCheckIn(checkIn, upsertMonitorConfig, scope);\n }\n\n return uuid4();\n}\n\n/**\n * Wraps a callback with a cron monitor check in. The check in will be sent to Sentry when the callback finishes.\n *\n * @param monitorSlug The distinct slug of the monitor.\n * @param callback Callback to be monitored\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction withMonitor(\n monitorSlug,\n callback,\n upsertMonitorConfig,\n) {\n const checkInId = captureCheckIn({ monitorSlug, status: 'in_progress' }, upsertMonitorConfig);\n const now = timestampInSeconds();\n\n function finishCheckIn(status) {\n captureCheckIn({ monitorSlug, status, checkInId, duration: timestampInSeconds() - now });\n }\n\n return withIsolationScope(() => {\n let maybePromiseResult;\n try {\n maybePromiseResult = callback();\n } catch (e) {\n finishCheckIn('error');\n throw e;\n }\n\n if (isThenable(maybePromiseResult)) {\n return maybePromiseResult.then(\n r => {\n finishCheckIn('ok');\n return r;\n },\n e => {\n finishCheckIn('error');\n throw e;\n },\n ) ;\n }\n finishCheckIn('ok');\n\n return maybePromiseResult;\n });\n}\n\n/**\n * Call `flush()` on the current client, if there is one. See {@link Client.flush}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue. Omitting this parameter will cause\n * the client to wait until all events are sent before resolving the promise.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function flush(timeout) {\n const client = getClient();\n if (client) {\n return client.flush(timeout);\n }\n DEBUG_BUILD && debug.warn('Cannot flush events. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * Call `close()` on the current client, if there is one. See {@link Client.close}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue before shutting down. Omitting this\n * parameter will cause the client to wait until all events are sent before disabling itself.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function close(timeout) {\n const client = getClient();\n if (client) {\n return client.close(timeout);\n }\n DEBUG_BUILD && debug.warn('Cannot flush events and disable SDK. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * Returns true if Sentry has been properly initialized.\n */\nfunction isInitialized() {\n return !!getClient();\n}\n\n/** If the SDK is initialized & enabled. */\nfunction isEnabled() {\n const client = getClient();\n return client?.getOptions().enabled !== false && !!client?.getTransport();\n}\n\n/**\n * Add an event processor.\n * This will be added to the current isolation scope, ensuring any event that is processed in the current execution\n * context will have the processor applied.\n */\nfunction addEventProcessor(callback) {\n getIsolationScope().addEventProcessor(callback);\n}\n\n/**\n * Start a session on the current isolation scope.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns the new active session\n */\nfunction startSession(context) {\n const isolationScope = getIsolationScope();\n const currentScope = getCurrentScope();\n\n // Will fetch userAgent if called from browser sdk\n const { userAgent } = GLOBAL_OBJ.navigator || {};\n\n const session = makeSession({\n user: currentScope.getUser() || isolationScope.getUser(),\n ...(userAgent && { userAgent }),\n ...context,\n });\n\n // End existing session if there's one\n const currentSession = isolationScope.getSession();\n if (currentSession?.status === 'ok') {\n updateSession(currentSession, { status: 'exited' });\n }\n\n endSession();\n\n // Afterwards we set the new session on the scope\n isolationScope.setSession(session);\n\n return session;\n}\n\n/**\n * End the session on the current isolation scope.\n */\nfunction endSession() {\n const isolationScope = getIsolationScope();\n const currentScope = getCurrentScope();\n\n const session = currentScope.getSession() || isolationScope.getSession();\n if (session) {\n closeSession(session);\n }\n _sendSessionUpdate();\n\n // the session is over; take it off of the scope\n isolationScope.setSession();\n}\n\n/**\n * Sends the current Session on the scope\n */\nfunction _sendSessionUpdate() {\n const isolationScope = getIsolationScope();\n const client = getClient();\n const session = isolationScope.getSession();\n if (session && client) {\n client.captureSession(session);\n }\n}\n\n/**\n * Sends the current session on the scope to Sentry\n *\n * @param end If set the session will be marked as exited and removed from the scope.\n * Defaults to `false`.\n */\nfunction captureSession(end = false) {\n // both send the update and pull the session from the scope\n if (end) {\n endSession();\n return;\n }\n\n // only send the update\n _sendSessionUpdate();\n}\n\nexport { addEventProcessor, captureCheckIn, captureEvent, captureException, captureMessage, captureSession, close, endSession, flush, isEnabled, isInitialized, lastEventId, setContext, setExtra, setExtras, setTag, setTags, setUser, startSession, withMonitor };\n//# sourceMappingURL=exports.js.map\n"],"x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/gaffe.js b/web/app/themes/haiku-atelier-2024/assets/js/gaffe.js new file mode 100644 index 00000000..f0d9238f --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/gaffe.js @@ -0,0 +1,4611 @@ +import { $ as getFramesFromEvent, A as extractExceptionKeysForMessage, B as isDOMException, C as timestampInSeconds$1, D as getEventDescription, E as checkOrSetAlreadyCaught, F as safeJoin, G as isParameterizedString, H as isErrorEvent, I as getComponentName, J as isRequest, K as isPlainObject$1, L as getLocationHref, M as getOriginalFunction, N as markFunctionWrapped$1, O as uuid4$1, P as isMatchingPattern, Q as createStackParser, R as htmlTreeAsString$1, S as dateTimestampInSeconds$1, T as addExceptionTypeValue, U as isEvent$1, V as isError$1, W as isInstanceOf$1, X as isThenable$1, Y as isString$1, Z as UNKNOWN_FUNCTION, _ as getIsolationScope, a as rejectedSyncPromise$1, at as getGlobalSingleton$2, b as merge, c as getDynamicSamplingContextFromScope, ct as GLOBAL_OBJ$1, d as dsnToString, dt as pipe, et as getFunctionName$1, f as makeDsn, g as getCurrentScope, h as getClient, i as prepareEvent, it as originalConsoleMethods$2, j as fill, k as addNonEnumerableProperty$1, l as DEFAULT_ENVIRONMENT, lt as DEBUG_BUILD$3, m as SEMANTIC_ATTRIBUTE_PROFILE_ID, n as captureException, nt as consoleSandbox$2, o as resolvedSyncPromise$1, ot as getSentryCarrier$1, p as SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME, q as isPrimitive$1, r as captureMessage, rt as debug$1, s as normalizeToSize, st as SDK_VERSION$2, t as captureEvent, tt as CONSOLE_LEVELS, u as showSpanDropWarning, ut as global, v as getTraceContextFromScope, w as addExceptionMechanism, x as updateSession, y as withScope, z as isDOMError } from "./exports.CurVqjr0.js"; +import { n as ENTETE_GLITCHTIP_RETRY_AFTER, t as ENTETE_GLITCHTIP_RATE_LIMITS } from "./api.CM5TBNEA.js"; + +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/handlers.js +var handlers$1 = {}; +var instrumented$1 = {}; +/** Add a handler function. */ +function addHandler$1(type, handler) { + handlers$1[type] = handlers$1[type] || []; + handlers$1[type].push(handler); +} +/** Maybe run an instrumentation function, unless it was already called. */ +function maybeInstrument$1(type, instrumentFn) { + if (!instrumented$1[type]) { + instrumented$1[type] = true; + try { + instrumentFn(); + } catch (e) { + DEBUG_BUILD$3 && debug$1.error(`Error while instrumenting ${type}`, e); + } + } +} +/** Trigger handlers for a given instrumentation type. */ +function triggerHandlers$1(type, data) { + const typeHandlers = type && handlers$1[type]; + if (!typeHandlers) return; + for (const handler of typeHandlers) try { + handler(data); + } catch (e) { + DEBUG_BUILD$3 && debug$1.error(`Error while triggering instrumentation handler.\nType: ${type}\nName: ${getFunctionName$1(handler)}\nError:`, e); + } +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/globalError.js +var _oldOnErrorHandler = null; +/** +* Add an instrumentation handler for when an error is captured by the global error handler. +* +* Use at your own risk, this might break without changelog notice, only used internally. +* @hidden +*/ +function addGlobalErrorInstrumentationHandler(handler) { + const type = "error"; + addHandler$1(type, handler); + maybeInstrument$1(type, instrumentError); +} +function instrumentError() { + _oldOnErrorHandler = GLOBAL_OBJ$1.onerror; + GLOBAL_OBJ$1.onerror = function(msg, url, line, column, error$2) { + triggerHandlers$1("error", { + column, + error: error$2, + line, + msg, + url + }); + if (_oldOnErrorHandler) return _oldOnErrorHandler.apply(this, arguments); + return false; + }; + GLOBAL_OBJ$1.onerror.__SENTRY_INSTRUMENTED__ = true; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/globalUnhandledRejection.js +var _oldOnUnhandledRejectionHandler = null; +/** +* Add an instrumentation handler for when an unhandled promise rejection is captured. +* +* Use at your own risk, this might break without changelog notice, only used internally. +* @hidden +*/ +function addGlobalUnhandledRejectionInstrumentationHandler(handler) { + const type = "unhandledrejection"; + addHandler$1(type, handler); + maybeInstrument$1(type, instrumentUnhandledRejection); +} +function instrumentUnhandledRejection() { + _oldOnUnhandledRejectionHandler = GLOBAL_OBJ$1.onunhandledrejection; + GLOBAL_OBJ$1.onunhandledrejection = function(e) { + triggerHandlers$1("unhandledrejection", e); + if (_oldOnUnhandledRejectionHandler) return _oldOnUnhandledRejectionHandler.apply(this, arguments); + return true; + }; + GLOBAL_OBJ$1.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/parseSampleRate.js +/** +* Parse a sample rate from a given value. +* This will either return a boolean or number sample rate, if the sample rate is valid (between 0 and 1). +* If a string is passed, we try to convert it to a number. +* +* Any invalid sample rate will return `undefined`. +*/ +function parseSampleRate(sampleRate) { + if (typeof sampleRate === "boolean") return Number(sampleRate); + const rate = typeof sampleRate === "string" ? parseFloat(sampleRate) : sampleRate; + if (typeof rate !== "number" || isNaN(rate) || rate < 0 || rate > 1) return; + return rate; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/should-ignore-span.js +function logIgnoredSpan(droppedSpan) { + debug$1.log(`Ignoring span ${droppedSpan.op} - ${droppedSpan.description} because it matches \`ignoreSpans\`.`); +} +/** +* Check if a span should be ignored based on the ignoreSpans configuration. +*/ +function shouldIgnoreSpan(span, ignoreSpans) { + if (!ignoreSpans?.length || !span.description) return false; + for (const pattern of ignoreSpans) { + if (isStringOrRegExp(pattern)) { + if (isMatchingPattern(span.description, pattern)) { + DEBUG_BUILD$3 && logIgnoredSpan(span); + return true; + } + continue; + } + if (!pattern.name && !pattern.op) continue; + const nameMatches = pattern.name ? isMatchingPattern(span.description, pattern.name) : true; + const opMatches = pattern.op ? span.op && isMatchingPattern(span.op, pattern.op) : true; + if (nameMatches && opMatches) { + DEBUG_BUILD$3 && logIgnoredSpan(span); + return true; + } + } + return false; +} +/** +* Takes a list of spans, and a span that was dropped, and re-parents the child spans of the dropped span to the parent of the dropped span, if possible. +* This mutates the spans array in place! +*/ +function reparentChildSpans(spans, dropSpan) { + const droppedSpanParentId = dropSpan.parent_span_id; + const droppedSpanId = dropSpan.span_id; + if (!droppedSpanParentId) return; + for (const span of spans) if (span.parent_span_id === droppedSpanId) span.parent_span_id = droppedSpanParentId; +} +function isStringOrRegExp(value) { + return typeof value === "string" || value instanceof RegExp; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/envelope.js +/** +* Creates an envelope. +* Make sure to always explicitly provide the generic to this function +* so that the envelope types resolve correctly. +*/ +function createEnvelope$1(headers, items = []) { + return [headers, items]; +} +/** +* Add an item to an envelope. +* Make sure to always explicitly provide the generic to this function +* so that the envelope types resolve correctly. +*/ +function addItemToEnvelope(envelope, newItem) { + const [headers, items] = envelope; + return [headers, [...items, newItem]]; +} +/** +* Encode a string to UTF8 array. +*/ +function encodeUTF8$1(input) { + const carrier = getSentryCarrier$1(GLOBAL_OBJ$1); + return carrier.encodePolyfill ? carrier.encodePolyfill(input) : new TextEncoder().encode(input); +} +/** +* Creates attachment envelope items +*/ +function createAttachmentEnvelopeItem(attachment) { + const buffer = typeof attachment.data === "string" ? encodeUTF8$1(attachment.data) : attachment.data; + return [{ + type: "attachment", + length: buffer.length, + filename: attachment.filename, + content_type: attachment.contentType, + attachment_type: attachment.attachmentType + }, buffer]; +} +/** Extracts the minimal SDK info from the metadata or an events */ +function getSdkMetadataForEnvelopeHeader(metadataOrEvent) { + if (!metadataOrEvent?.sdk) return; + const { name, version } = metadataOrEvent.sdk; + return { + name, + version + }; +} +/** +* Creates event envelope headers, based on event, sdk info and tunnel +* Note: This function was extracted from the core package to make it available in Replay +*/ +function createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn) { + const dynamicSamplingContext = event.sdkProcessingMetadata?.dynamicSamplingContext; + return { + event_id: event.event_id, + sent_at: (/* @__PURE__ */ new Date()).toISOString(), + ...sdkInfo && { sdk: sdkInfo }, + ...!!tunnel && dsn && { dsn: dsnToString(dsn) }, + ...dynamicSamplingContext && { trace: dynamicSamplingContext } + }; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/envelope.js +/** +* Apply SdkInfo (name, version, packages, integrations) to the corresponding event key. +* Merge with existing data if any. +* +* @internal, exported only for testing +**/ +function _enhanceEventWithSdkInfo(event, newSdkInfo) { + if (!newSdkInfo) return event; + const eventSdkInfo = event.sdk || {}; + event.sdk = { + ...eventSdkInfo, + name: eventSdkInfo.name || newSdkInfo.name, + version: eventSdkInfo.version || newSdkInfo.version, + integrations: [...event.sdk?.integrations || [], ...newSdkInfo.integrations || []], + packages: [...event.sdk?.packages || [], ...newSdkInfo.packages || []], + settings: event.sdk?.settings || newSdkInfo.settings ? { + ...event.sdk?.settings, + ...newSdkInfo.settings + } : void 0 + }; + return event; +} +/** Creates an envelope from a Session */ +function createSessionEnvelope(session, dsn, metadata, tunnel) { + const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata); + return createEnvelope$1({ + sent_at: (/* @__PURE__ */ new Date()).toISOString(), + ...sdkInfo && { sdk: sdkInfo }, + ...!!tunnel && dsn && { dsn: dsnToString(dsn) } + }, ["aggregates" in session ? [{ type: "sessions" }, session] : [{ type: "session" }, session.toJSON()]]); +} +/** +* Create an Envelope from an event. +*/ +function createEventEnvelope(event, dsn, metadata, tunnel) { + const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata); + const eventType = event.type && event.type !== "replay_event" ? event.type : "event"; + _enhanceEventWithSdkInfo(event, metadata?.sdk); + const envelopeHeaders = createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn); + delete event.sdkProcessingMetadata; + return createEnvelope$1(envelopeHeaders, [[{ type: eventType }, event]]); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/api.js +var SENTRY_API_VERSION = "7"; +/** Returns the prefix to construct Sentry ingestion API endpoints. */ +function getBaseApiEndpoint(dsn) { + const protocol = dsn.protocol ? `${dsn.protocol}:` : ""; + const port = dsn.port ? `:${dsn.port}` : ""; + return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ""}/api/`; +} +/** Returns the ingest API endpoint for target. */ +function _getIngestEndpoint(dsn) { + return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`; +} +/** Returns a URL-encoded string with auth config suitable for a query string. */ +function _encodedAuth(dsn, sdkInfo) { + const params = { sentry_version: SENTRY_API_VERSION }; + if (dsn.publicKey) params.sentry_key = dsn.publicKey; + if (sdkInfo) params.sentry_client = `${sdkInfo.name}/${sdkInfo.version}`; + return new URLSearchParams(params).toString(); +} +/** +* Returns the envelope endpoint URL with auth in the query string. +* +* Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests. +*/ +function getEnvelopeEndpointWithUrlEncodedAuth(dsn, tunnel, sdkInfo) { + return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integration.js +var installedIntegrations = []; +/** +* Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default +* integrations are added unless they were already provided before. +* @param integrations array of integration instances +* @param withDefault should enable default integrations +*/ +function setupIntegrations(client$1, integrations) { + const integrationIndex = {}; + integrations.forEach((integration) => { + if (integration) setupIntegration(client$1, integration, integrationIndex); + }); + return integrationIndex; +} +/** +* Execute the `afterAllSetup` hooks of the given integrations. +*/ +function afterSetupIntegrations(client$1, integrations) { + for (const integration of integrations) if (integration?.afterAllSetup) integration.afterAllSetup(client$1); +} +/** Setup a single integration. */ +function setupIntegration(client$1, integration, integrationIndex) { + if (integrationIndex[integration.name]) { + DEBUG_BUILD$3 && debug$1.log(`Integration skipped because it was already installed: ${integration.name}`); + return; + } + integrationIndex[integration.name] = integration; + if (installedIntegrations.indexOf(integration.name) === -1 && typeof integration.setupOnce === "function") { + integration.setupOnce(); + installedIntegrations.push(integration.name); + } + if (integration.setup && typeof integration.setup === "function") integration.setup(client$1); + if (typeof integration.preprocessEvent === "function") { + const callback = integration.preprocessEvent.bind(integration); + client$1.on("preprocessEvent", (event, hint) => callback(event, hint, client$1)); + } + if (typeof integration.processEvent === "function") { + const callback = integration.processEvent.bind(integration); + const processor = Object.assign((event, hint) => callback(event, hint, client$1), { id: integration.name }); + client$1.addEventProcessor(processor); + } + DEBUG_BUILD$3 && debug$1.log(`Integration installed: ${integration.name}`); +} +/** +* Define an integration function that can be used to create an integration instance. +* Note that this by design hides the implementation details of the integration, as they are considered internal. +*/ +function defineIntegration(fn) { + return fn; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/logs/envelope.js +/** +* Creates a log container envelope item for a list of logs. +* +* @param items - The logs to include in the envelope. +* @returns The created log container envelope item. +*/ +function createLogContainerEnvelopeItem(items) { + return [{ + type: "log", + item_count: items.length, + content_type: "application/vnd.sentry.items.log+json" + }, { items }]; +} +/** +* Creates an envelope for a list of logs. +* +* Logs from multiple traces can be included in the same envelope. +* +* @param logs - The logs to include in the envelope. +* @param metadata - The metadata to include in the envelope. +* @param tunnel - The tunnel to include in the envelope. +* @param dsn - The DSN to include in the envelope. +* @returns The created envelope. +*/ +function createLogEnvelope(logs, metadata, tunnel, dsn) { + const headers = {}; + if (metadata?.sdk) headers.sdk = { + name: metadata.sdk.name, + version: metadata.sdk.version + }; + if (!!tunnel && !!dsn) headers.dsn = dsnToString(dsn); + return createEnvelope$1(headers, [createLogContainerEnvelopeItem(logs)]); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/logs/internal.js +/** +* Flushes the logs buffer to Sentry. +* +* @param client - A client. +* @param maybeLogBuffer - A log buffer. Uses the log buffer for the given client if not provided. +* +* @experimental This method will experience breaking changes. This is not yet part of +* the stable Sentry SDK API and can be changed or removed without warning. +*/ +function _INTERNAL_flushLogsBuffer(client$1, maybeLogBuffer) { + const logBuffer = maybeLogBuffer ?? _INTERNAL_getLogBuffer(client$1) ?? []; + if (logBuffer.length === 0) return; + const clientOptions = client$1.getOptions(); + const envelope = createLogEnvelope(logBuffer, clientOptions._metadata, clientOptions.tunnel, client$1.getDsn()); + _getBufferMap$1().set(client$1, []); + client$1.emit("flushLogs"); + client$1.sendEnvelope(envelope); +} +/** +* Returns the log buffer for a given client. +* +* Exported for testing purposes. +* +* @param client - The client to get the log buffer for. +* @returns The log buffer for the given client. +*/ +function _INTERNAL_getLogBuffer(client$1) { + return _getBufferMap$1().get(client$1); +} +function _getBufferMap$1() { + return getGlobalSingleton$2("clientToLogBufferMap", () => /* @__PURE__ */ new WeakMap()); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/metrics/envelope.js +/** +* Creates a metric container envelope item for a list of metrics. +* +* @param items - The metrics to include in the envelope. +* @returns The created metric container envelope item. +*/ +function createMetricContainerEnvelopeItem(items) { + return [{ + type: "trace_metric", + item_count: items.length, + content_type: "application/vnd.sentry.items.trace-metric+json" + }, { items }]; +} +/** +* Creates an envelope for a list of metrics. +* +* Metrics from multiple traces can be included in the same envelope. +* +* @param metrics - The metrics to include in the envelope. +* @param metadata - The metadata to include in the envelope. +* @param tunnel - The tunnel to include in the envelope. +* @param dsn - The DSN to include in the envelope. +* @returns The created envelope. +*/ +function createMetricEnvelope(metrics, metadata, tunnel, dsn) { + const headers = {}; + if (metadata?.sdk) headers.sdk = { + name: metadata.sdk.name, + version: metadata.sdk.version + }; + if (!!tunnel && !!dsn) headers.dsn = dsnToString(dsn); + return createEnvelope$1(headers, [createMetricContainerEnvelopeItem(metrics)]); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/metrics/internal.js +/** +* Flushes the metrics buffer to Sentry. +* +* @param client - A client. +* @param maybeMetricBuffer - A metric buffer. Uses the metric buffer for the given client if not provided. +* +* @experimental This method will experience breaking changes. This is not yet part of +* the stable Sentry SDK API and can be changed or removed without warning. +*/ +function _INTERNAL_flushMetricsBuffer(client$1, maybeMetricBuffer) { + const metricBuffer = maybeMetricBuffer ?? _INTERNAL_getMetricBuffer(client$1) ?? []; + if (metricBuffer.length === 0) return; + const clientOptions = client$1.getOptions(); + const envelope = createMetricEnvelope(metricBuffer, clientOptions._metadata, clientOptions.tunnel, client$1.getDsn()); + _getBufferMap().set(client$1, []); + client$1.emit("flushMetrics"); + client$1.sendEnvelope(envelope); +} +/** +* Returns the metric buffer for a given client. +* +* Exported for testing purposes. +* +* @param client - The client to get the metric buffer for. +* @returns The metric buffer for the given client. +*/ +function _INTERNAL_getMetricBuffer(client$1) { + return _getBufferMap().get(client$1); +} +function _getBufferMap() { + return getGlobalSingleton$2("clientToMetricBufferMap", () => /* @__PURE__ */ new WeakMap()); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/clientreport.js +/** +* Creates client report envelope +* @param discarded_events An array of discard events +* @param dsn A DSN that can be set on the header. Optional. +*/ +function createClientReportEnvelope(discarded_events, dsn, timestamp) { + const clientReportItem = [{ type: "client_report" }, { + timestamp: timestamp || dateTimestampInSeconds$1(), + discarded_events + }]; + return createEnvelope$1(dsn ? { dsn } : {}, [clientReportItem]); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/eventUtils.js +/** +* Get a list of possible event messages from a Sentry event. +*/ +function getPossibleEventMessages(event) { + const possibleMessages = []; + if (event.message) possibleMessages.push(event.message); + try { + const lastException = event.exception.values[event.exception.values.length - 1]; + if (lastException?.value) { + possibleMessages.push(lastException.value); + if (lastException.type) possibleMessages.push(`${lastException.type}: ${lastException.value}`); + } + } catch {} + return possibleMessages; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/transactionEvent.js +/** +* Converts a transaction event to a span JSON object. +*/ +function convertTransactionEventToSpanJson(event) { + const { trace_id, parent_span_id, span_id, status, origin, data, op } = event.contexts?.trace ?? {}; + return { + data: data ?? {}, + description: event.transaction, + op, + parent_span_id, + span_id: span_id ?? "", + start_timestamp: event.start_timestamp ?? 0, + status, + timestamp: event.timestamp, + trace_id: trace_id ?? "", + origin, + profile_id: data?.[SEMANTIC_ATTRIBUTE_PROFILE_ID], + exclusive_time: data?.[SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME], + measurements: event.measurements, + is_segment: true + }; +} +/** +* Converts a span JSON object to a transaction event. +*/ +function convertSpanJsonToTransactionEvent(span) { + return { + type: "transaction", + timestamp: span.timestamp, + start_timestamp: span.start_timestamp, + transaction: span.description, + contexts: { trace: { + trace_id: span.trace_id, + span_id: span.span_id, + parent_span_id: span.parent_span_id, + op: span.op, + status: span.status, + origin: span.origin, + data: { + ...span.data, + ...span.profile_id && { ["sentry.profile_id"]: span.profile_id }, + ...span.exclusive_time && { ["sentry.exclusive_time"]: span.exclusive_time } + } + } }, + measurements: span.measurements + }; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/client.js +var ALREADY_SEEN_ERROR = "Not capturing exception because it's already been captured."; +var MISSING_RELEASE_FOR_SESSION_ERROR = "Discarded session because of missing or non-string release"; +var INTERNAL_ERROR_SYMBOL = Symbol.for("SentryInternalError"); +var DO_NOT_SEND_EVENT_SYMBOL = Symbol.for("SentryDoNotSendEventError"); +var DEFAULT_FLUSH_INTERVAL = 5e3; +function _makeInternalError(message) { + return { + message, + [INTERNAL_ERROR_SYMBOL]: true + }; +} +function _makeDoNotSendEventError(message) { + return { + message, + [DO_NOT_SEND_EVENT_SYMBOL]: true + }; +} +function _isInternalError(error$2) { + return !!error$2 && typeof error$2 === "object" && INTERNAL_ERROR_SYMBOL in error$2; +} +function _isDoNotSendEventError(error$2) { + return !!error$2 && typeof error$2 === "object" && DO_NOT_SEND_EVENT_SYMBOL in error$2; +} +/** +* Sets up weight-based flushing for logs or metrics. +* This helper function encapsulates the common pattern of: +* 1. Tracking accumulated weight of items +* 2. Flushing when weight exceeds threshold (800KB) +* 3. Flushing after idle timeout if no new items arrive +* +* Uses closure variables to track weight and timeout state. +*/ +function setupWeightBasedFlushing(client$1, afterCaptureHook, flushHook, estimateSizeFn, flushFn) { + let weight = 0; + let flushTimeout; + client$1.on(flushHook, () => { + weight = 0; + clearTimeout(flushTimeout); + }); + client$1.on(afterCaptureHook, (item) => { + weight += estimateSizeFn(item); + if (weight >= 8e5) flushFn(client$1); + else { + clearTimeout(flushTimeout); + flushTimeout = setTimeout(() => { + flushFn(client$1); + }, DEFAULT_FLUSH_INTERVAL); + } + }); + client$1.on("flush", () => { + flushFn(client$1); + }); +} +/** +* Base implementation for all JavaScript SDK clients. +* +* Call the constructor with the corresponding options +* specific to the client subclass. To access these options later, use +* {@link Client.getOptions}. +* +* If a Dsn is specified in the options, it will be parsed and stored. Use +* {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is +* invalid, the constructor will throw a {@link SentryException}. Note that +* without a valid Dsn, the SDK will not send any events to Sentry. +* +* Before sending an event, it is passed through +* {@link Client._prepareEvent} to add SDK information and scope data +* (breadcrumbs and context). To add more custom information, override this +* method and extend the resulting prepared event. +* +* To issue automatically created events (e.g. via instrumentation), use +* {@link Client.captureEvent}. It will prepare the event and pass it through +* the callback lifecycle. To issue auto-breadcrumbs, use +* {@link Client.addBreadcrumb}. +* +* @example +* class NodeClient extends Client { +* public constructor(options: NodeOptions) { +* super(options); +* } +* +* // ... +* } +*/ +var Client = class { + /** Options passed to the SDK. */ + /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */ + /** Array of set up integrations. */ + /** Number of calls being processed */ + /** Holds flushable */ + /** + * Initializes this client instance. + * + * @param options Options for the client. + */ + constructor(options) { + this._options = options; + this._integrations = {}; + this._numProcessing = 0; + this._outcomes = {}; + this._hooks = {}; + this._eventProcessors = []; + if (options.dsn) this._dsn = makeDsn(options.dsn); + else DEBUG_BUILD$3 && debug$1.warn("No DSN provided, client will not send events."); + if (this._dsn) { + const url = getEnvelopeEndpointWithUrlEncodedAuth(this._dsn, options.tunnel, options._metadata ? options._metadata.sdk : void 0); + this._transport = options.transport({ + tunnel: this._options.tunnel, + recordDroppedEvent: this.recordDroppedEvent.bind(this), + ...options.transportOptions, + url + }); + } + if (this._options.enableLogs) setupWeightBasedFlushing(this, "afterCaptureLog", "flushLogs", estimateLogSizeInBytes, _INTERNAL_flushLogsBuffer); + if (this._options._experiments?.enableMetrics) setupWeightBasedFlushing(this, "afterCaptureMetric", "flushMetrics", estimateMetricSizeInBytes, _INTERNAL_flushMetricsBuffer); + } + /** + * Captures an exception event and sends it to Sentry. + * + * Unlike `captureException` exported from every SDK, this method requires that you pass it the current scope. + */ + captureException(exception, hint, scope) { + const eventId = uuid4$1(); + if (checkOrSetAlreadyCaught(exception)) { + DEBUG_BUILD$3 && debug$1.log(ALREADY_SEEN_ERROR); + return eventId; + } + const hintWithEventId = { + event_id: eventId, + ...hint + }; + this._process(this.eventFromException(exception, hintWithEventId).then((event) => this._captureEvent(event, hintWithEventId, scope))); + return hintWithEventId.event_id; + } + /** + * Captures a message event and sends it to Sentry. + * + * Unlike `captureMessage` exported from every SDK, this method requires that you pass it the current scope. + */ + captureMessage(message, level, hint, currentScope) { + const hintWithEventId = { + event_id: uuid4$1(), + ...hint + }; + const eventMessage = isParameterizedString(message) ? message : String(message); + const promisedEvent = isPrimitive$1(message) ? this.eventFromMessage(eventMessage, level, hintWithEventId) : this.eventFromException(message, hintWithEventId); + this._process(promisedEvent.then((event) => this._captureEvent(event, hintWithEventId, currentScope))); + return hintWithEventId.event_id; + } + /** + * Captures a manually created event and sends it to Sentry. + * + * Unlike `captureEvent` exported from every SDK, this method requires that you pass it the current scope. + */ + captureEvent(event, hint, currentScope) { + const eventId = uuid4$1(); + if (hint?.originalException && checkOrSetAlreadyCaught(hint.originalException)) { + DEBUG_BUILD$3 && debug$1.log(ALREADY_SEEN_ERROR); + return eventId; + } + const hintWithEventId = { + event_id: eventId, + ...hint + }; + const sdkProcessingMetadata = event.sdkProcessingMetadata || {}; + const capturedSpanScope = sdkProcessingMetadata.capturedSpanScope; + const capturedSpanIsolationScope = sdkProcessingMetadata.capturedSpanIsolationScope; + this._process(this._captureEvent(event, hintWithEventId, capturedSpanScope || currentScope, capturedSpanIsolationScope)); + return hintWithEventId.event_id; + } + /** + * Captures a session. + */ + captureSession(session) { + this.sendSession(session); + updateSession(session, { init: false }); + } + /** + * Create a cron monitor check in and send it to Sentry. This method is not available on all clients. + * + * @param checkIn An object that describes a check in. + * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want + * to create a monitor automatically when sending a check in. + * @param scope An optional scope containing event metadata. + * @returns A string representing the id of the check in. + */ + /** + * Get the current Dsn. + */ + getDsn() { + return this._dsn; + } + /** + * Get the current options. + */ + getOptions() { + return this._options; + } + /** + * Get the SDK metadata. + * @see SdkMetadata + */ + getSdkMetadata() { + return this._options._metadata; + } + /** + * Returns the transport that is used by the client. + * Please note that the transport gets lazy initialized so it will only be there once the first event has been sent. + */ + getTransport() { + return this._transport; + } + /** + * Wait for all events to be sent or the timeout to expire, whichever comes first. + * + * @param timeout Maximum time in ms the client should wait for events to be flushed. Omitting this parameter will + * cause the client to wait until all events are sent before resolving the promise. + * @returns A promise that will resolve with `true` if all events are sent before the timeout, or `false` if there are + * still events in the queue when the timeout is reached. + */ + async flush(timeout) { + const transport = this._transport; + if (!transport) return true; + this.emit("flush"); + const clientFinished = await this._isClientDoneProcessing(timeout); + const transportFlushed = await transport.flush(timeout); + return clientFinished && transportFlushed; + } + /** + * Flush the event queue and set the client to `enabled = false`. See {@link Client.flush}. + * + * @param {number} timeout Maximum time in ms the client should wait before shutting down. Omitting this parameter will cause + * the client to wait until all events are sent before disabling itself. + * @returns {Promise} A promise which resolves to `true` if the flush completes successfully before the timeout, or `false` if + * it doesn't. + */ + async close(timeout) { + const result = await this.flush(timeout); + this.getOptions().enabled = false; + this.emit("close"); + return result; + } + /** + * Get all installed event processors. + */ + getEventProcessors() { + return this._eventProcessors; + } + /** + * Adds an event processor that applies to any event processed by this client. + */ + addEventProcessor(eventProcessor) { + this._eventProcessors.push(eventProcessor); + } + /** + * Initialize this client. + * Call this after the client was set on a scope. + */ + init() { + if (this._isEnabled() || this._options.integrations.some(({ name }) => name.startsWith("Spotlight"))) this._setupIntegrations(); + } + /** + * Gets an installed integration by its name. + * + * @returns {Integration|undefined} The installed integration or `undefined` if no integration with that `name` was installed. + */ + getIntegrationByName(integrationName) { + return this._integrations[integrationName]; + } + /** + * Add an integration to the client. + * This can be used to e.g. lazy load integrations. + * In most cases, this should not be necessary, + * and you're better off just passing the integrations via `integrations: []` at initialization time. + * However, if you find the need to conditionally load & add an integration, you can use `addIntegration` to do so. + */ + addIntegration(integration) { + const isAlreadyInstalled = this._integrations[integration.name]; + setupIntegration(this, integration, this._integrations); + if (!isAlreadyInstalled) afterSetupIntegrations(this, [integration]); + } + /** + * Send a fully prepared event to Sentry. + */ + sendEvent(event, hint = {}) { + this.emit("beforeSendEvent", event, hint); + let env = createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel); + for (const attachment of hint.attachments || []) env = addItemToEnvelope(env, createAttachmentEnvelopeItem(attachment)); + this.sendEnvelope(env).then((sendResponse) => this.emit("afterSendEvent", event, sendResponse)); + } + /** + * Send a session or session aggregrates to Sentry. + */ + sendSession(session) { + const { release: clientReleaseOption, environment: clientEnvironmentOption = DEFAULT_ENVIRONMENT } = this._options; + if ("aggregates" in session) { + const sessionAttrs = session.attrs || {}; + if (!sessionAttrs.release && !clientReleaseOption) { + DEBUG_BUILD$3 && debug$1.warn(MISSING_RELEASE_FOR_SESSION_ERROR); + return; + } + sessionAttrs.release = sessionAttrs.release || clientReleaseOption; + sessionAttrs.environment = sessionAttrs.environment || clientEnvironmentOption; + session.attrs = sessionAttrs; + } else { + if (!session.release && !clientReleaseOption) { + DEBUG_BUILD$3 && debug$1.warn(MISSING_RELEASE_FOR_SESSION_ERROR); + return; + } + session.release = session.release || clientReleaseOption; + session.environment = session.environment || clientEnvironmentOption; + } + this.emit("beforeSendSession", session); + const env = createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel); + this.sendEnvelope(env); + } + /** + * Record on the client that an event got dropped (ie, an event that will not be sent to Sentry). + */ + recordDroppedEvent(reason, category, count = 1) { + if (this._options.sendClientReports) { + const key = `${reason}:${category}`; + DEBUG_BUILD$3 && debug$1.log(`Recording outcome: "${key}"${count > 1 ? ` (${count} times)` : ""}`); + this._outcomes[key] = (this._outcomes[key] || 0) + count; + } + } + /** + * Register a callback for whenever a span is started. + * Receives the span as argument. + * @returns {() => void} A function that, when executed, removes the registered callback. + */ + /** + * Register a hook on this client. + */ + on(hook, callback) { + const hookCallbacks = this._hooks[hook] = this._hooks[hook] || /* @__PURE__ */ new Set(); + const uniqueCallback = (...args) => callback(...args); + hookCallbacks.add(uniqueCallback); + return () => { + hookCallbacks.delete(uniqueCallback); + }; + } + /** Fire a hook whenever a span starts. */ + /** + * Emit a hook that was previously registered via `on()`. + */ + emit(hook, ...rest) { + const callbacks = this._hooks[hook]; + if (callbacks) callbacks.forEach((callback) => callback(...rest)); + } + /** + * Send an envelope to Sentry. + */ + async sendEnvelope(envelope) { + this.emit("beforeEnvelope", envelope); + if (this._isEnabled() && this._transport) try { + return await this._transport.send(envelope); + } catch (reason) { + DEBUG_BUILD$3 && debug$1.error("Error while sending envelope:", reason); + return {}; + } + DEBUG_BUILD$3 && debug$1.error("Transport disabled"); + return {}; + } + /** Setup integrations for this client. */ + _setupIntegrations() { + const { integrations } = this._options; + this._integrations = setupIntegrations(this, integrations); + afterSetupIntegrations(this, integrations); + } + /** Updates existing session based on the provided event */ + _updateSessionFromEvent(session, event) { + let crashed = event.level === "fatal"; + let errored = false; + const exceptions = event.exception?.values; + if (exceptions) { + errored = true; + for (const ex of exceptions) if (ex.mechanism?.handled === false) { + crashed = true; + break; + } + } + const sessionNonTerminal = session.status === "ok"; + if (sessionNonTerminal && session.errors === 0 || sessionNonTerminal && crashed) { + updateSession(session, { + ...crashed && { status: "crashed" }, + errors: session.errors || Number(errored || crashed) + }); + this.captureSession(session); + } + } + /** + * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying + * "no" (resolving to `false`) in order to give the client a chance to potentially finish first. + * + * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not + * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to + * `true`. + * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and + * `false` otherwise + */ + async _isClientDoneProcessing(timeout) { + let ticked = 0; + while (!timeout || ticked < timeout) { + await new Promise((resolve) => setTimeout(resolve, 1)); + if (!this._numProcessing) return true; + ticked++; + } + return false; + } + /** Determines whether this SDK is enabled and a transport is present. */ + _isEnabled() { + return this.getOptions().enabled !== false && this._transport !== void 0; + } + /** + * Adds common information to events. + * + * The information includes release and environment from `options`, + * breadcrumbs and context (extra, tags and user) from the scope. + * + * Information that is already present in the event is never overwritten. For + * nested objects, such as the context, keys are merged. + * + * @param event The original event. + * @param hint May contain additional information about the original exception. + * @param currentScope A scope containing event metadata. + * @returns A new event with more information. + */ + _prepareEvent(event, hint, currentScope, isolationScope) { + const options = this.getOptions(); + const integrations = Object.keys(this._integrations); + if (!hint.integrations && integrations?.length) hint.integrations = integrations; + this.emit("preprocessEvent", event, hint); + if (!event.type) isolationScope.setLastEventId(event.event_id || hint.event_id); + return prepareEvent(options, event, hint, currentScope, this, isolationScope).then((evt) => { + if (evt === null) return evt; + this.emit("postprocessEvent", evt, hint); + evt.contexts = { + trace: getTraceContextFromScope(currentScope), + ...evt.contexts + }; + evt.sdkProcessingMetadata = { + dynamicSamplingContext: getDynamicSamplingContextFromScope(this, currentScope), + ...evt.sdkProcessingMetadata + }; + return evt; + }); + } + /** + * Processes the event and logs an error in case of rejection + * @param event + * @param hint + * @param scope + */ + _captureEvent(event, hint = {}, currentScope = getCurrentScope(), isolationScope = getIsolationScope()) { + if (DEBUG_BUILD$3 && isErrorEvent$1(event)) debug$1.log(`Captured error event \`${getPossibleEventMessages(event)[0] || ""}\``); + return this._processEvent(event, hint, currentScope, isolationScope).then((finalEvent) => { + return finalEvent.event_id; + }, (reason) => { + if (DEBUG_BUILD$3) if (_isDoNotSendEventError(reason)) debug$1.log(reason.message); + else if (_isInternalError(reason)) debug$1.warn(reason.message); + else debug$1.warn(reason); + }); + } + /** + * Processes an event (either error or message) and sends it to Sentry. + * + * This also adds breadcrumbs and context information to the event. However, + * platform specific meta data (such as the User's IP address) must be added + * by the SDK implementor. + * + * + * @param event The event to send to Sentry. + * @param hint May contain additional information about the original exception. + * @param currentScope A scope containing event metadata. + * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send. + */ + _processEvent(event, hint, currentScope, isolationScope) { + const options = this.getOptions(); + const { sampleRate } = options; + const isTransaction = isTransactionEvent(event); + const isError$2 = isErrorEvent$1(event); + const eventType = event.type || "error"; + const beforeSendLabel = `before send for type \`${eventType}\``; + const parsedSampleRate = typeof sampleRate === "undefined" ? void 0 : parseSampleRate(sampleRate); + if (isError$2 && typeof parsedSampleRate === "number" && Math.random() > parsedSampleRate) { + this.recordDroppedEvent("sample_rate", "error"); + return rejectedSyncPromise$1(_makeDoNotSendEventError(`Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`)); + } + const dataCategory = eventType === "replay_event" ? "replay" : eventType; + return this._prepareEvent(event, hint, currentScope, isolationScope).then((prepared) => { + if (prepared === null) { + this.recordDroppedEvent("event_processor", dataCategory); + throw _makeDoNotSendEventError("An event processor returned `null`, will not send event."); + } + if (hint.data && hint.data.__sentry__ === true) return prepared; + return _validateBeforeSendResult(processBeforeSend(this, options, prepared, hint), beforeSendLabel); + }).then((processedEvent) => { + if (processedEvent === null) { + this.recordDroppedEvent("before_send", dataCategory); + if (isTransaction) { + const spanCount = 1 + (event.spans || []).length; + this.recordDroppedEvent("before_send", "span", spanCount); + } + throw _makeDoNotSendEventError(`${beforeSendLabel} returned \`null\`, will not send event.`); + } + const session = currentScope.getSession() || isolationScope.getSession(); + if (isError$2 && session) this._updateSessionFromEvent(session, processedEvent); + if (isTransaction) { + const droppedSpanCount = (processedEvent.sdkProcessingMetadata?.spanCountBeforeProcessing || 0) - (processedEvent.spans ? processedEvent.spans.length : 0); + if (droppedSpanCount > 0) this.recordDroppedEvent("before_send", "span", droppedSpanCount); + } + const transactionInfo = processedEvent.transaction_info; + if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) { + const source = "custom"; + processedEvent.transaction_info = { + ...transactionInfo, + source + }; + } + this.sendEvent(processedEvent, hint); + return processedEvent; + }).then(null, (reason) => { + if (_isDoNotSendEventError(reason) || _isInternalError(reason)) throw reason; + this.captureException(reason, { + mechanism: { + handled: false, + type: "internal" + }, + data: { __sentry__: true }, + originalException: reason + }); + throw _makeInternalError(`Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\nReason: ${reason}`); + }); + } + /** + * Occupies the client with processing and event + */ + _process(promise) { + this._numProcessing++; + promise.then((value) => { + this._numProcessing--; + return value; + }, (reason) => { + this._numProcessing--; + return reason; + }); + } + /** + * Clears outcomes on this client and returns them. + */ + _clearOutcomes() { + const outcomes = this._outcomes; + this._outcomes = {}; + return Object.entries(outcomes).map(([key, quantity]) => { + const [reason, category] = key.split(":"); + return { + reason, + category, + quantity + }; + }); + } + /** + * Sends client reports as an envelope. + */ + _flushOutcomes() { + DEBUG_BUILD$3 && debug$1.log("Flushing outcomes..."); + const outcomes = this._clearOutcomes(); + if (outcomes.length === 0) { + DEBUG_BUILD$3 && debug$1.log("No outcomes to send"); + return; + } + if (!this._dsn) { + DEBUG_BUILD$3 && debug$1.log("No dsn provided, will not send outcomes"); + return; + } + DEBUG_BUILD$3 && debug$1.log("Sending outcomes:", outcomes); + const envelope = createClientReportEnvelope(outcomes, this._options.tunnel && dsnToString(this._dsn)); + this.sendEnvelope(envelope); + } +}; +/** +* Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so. +*/ +function _validateBeforeSendResult(beforeSendResult, beforeSendLabel) { + const invalidValueError = `${beforeSendLabel} must return \`null\` or a valid event.`; + if (isThenable$1(beforeSendResult)) return beforeSendResult.then((event) => { + if (!isPlainObject$1(event) && event !== null) throw _makeInternalError(invalidValueError); + return event; + }, (e) => { + throw _makeInternalError(`${beforeSendLabel} rejected with ${e}`); + }); + else if (!isPlainObject$1(beforeSendResult) && beforeSendResult !== null) throw _makeInternalError(invalidValueError); + return beforeSendResult; +} +/** +* Process the matching `beforeSendXXX` callback. +*/ +function processBeforeSend(client$1, options, event, hint) { + const { beforeSend, beforeSendTransaction, beforeSendSpan, ignoreSpans } = options; + let processedEvent = event; + if (isErrorEvent$1(processedEvent) && beforeSend) return beforeSend(processedEvent, hint); + if (isTransactionEvent(processedEvent)) { + if (beforeSendSpan || ignoreSpans) { + const rootSpanJson = convertTransactionEventToSpanJson(processedEvent); + if (ignoreSpans?.length && shouldIgnoreSpan(rootSpanJson, ignoreSpans)) return null; + if (beforeSendSpan) { + const processedRootSpanJson = beforeSendSpan(rootSpanJson); + if (!processedRootSpanJson) showSpanDropWarning(); + else processedEvent = merge(event, convertSpanJsonToTransactionEvent(processedRootSpanJson)); + } + if (processedEvent.spans) { + const processedSpans = []; + const initialSpans = processedEvent.spans; + for (const span of initialSpans) { + if (ignoreSpans?.length && shouldIgnoreSpan(span, ignoreSpans)) { + reparentChildSpans(initialSpans, span); + continue; + } + if (beforeSendSpan) { + const processedSpan = beforeSendSpan(span); + if (!processedSpan) { + showSpanDropWarning(); + processedSpans.push(span); + } else processedSpans.push(processedSpan); + } else processedSpans.push(span); + } + const droppedSpans = processedEvent.spans.length - processedSpans.length; + if (droppedSpans) client$1.recordDroppedEvent("before_send", "span", droppedSpans); + processedEvent.spans = processedSpans; + } + } + if (beforeSendTransaction) { + if (processedEvent.spans) { + const spanCountBefore = processedEvent.spans.length; + processedEvent.sdkProcessingMetadata = { + ...event.sdkProcessingMetadata, + spanCountBeforeProcessing: spanCountBefore + }; + } + return beforeSendTransaction(processedEvent, hint); + } + } + return processedEvent; +} +function isErrorEvent$1(event) { + return event.type === void 0; +} +function isTransactionEvent(event) { + return event.type === "transaction"; +} +/** +* Estimate the size of a metric in bytes. +* +* @param metric - The metric to estimate the size of. +* @returns The estimated size of the metric in bytes. +*/ +function estimateMetricSizeInBytes(metric) { + let weight = 0; + if (metric.name) weight += metric.name.length * 2; + if (typeof metric.value === "string") weight += metric.value.length * 2; + else weight += 8; + return weight + estimateAttributesSizeInBytes(metric.attributes); +} +/** +* Estimate the size of a log in bytes. +* +* @param log - The log to estimate the size of. +* @returns The estimated size of the log in bytes. +*/ +function estimateLogSizeInBytes(log$2) { + let weight = 0; + if (log$2.message) weight += log$2.message.length * 2; + return weight + estimateAttributesSizeInBytes(log$2.attributes); +} +/** +* Estimate the size of attributes in bytes. +* +* @param attributes - The attributes object to estimate the size of. +* @returns The estimated size of the attributes in bytes. +*/ +function estimateAttributesSizeInBytes(attributes) { + if (!attributes) return 0; + let weight = 0; + Object.values(attributes).forEach((value) => { + if (Array.isArray(value)) weight += value.length * estimatePrimitiveSizeInBytes(value[0]); + else if (isPrimitive$1(value)) weight += estimatePrimitiveSizeInBytes(value); + else weight += 100; + }); + return weight; +} +function estimatePrimitiveSizeInBytes(value) { + if (typeof value === "string") return value.length * 2; + else if (typeof value === "number") return 8; + else if (typeof value === "boolean") return 4; + return 0; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/url.js +var DEFAULT_BASE_URL = "thismessage:/"; +/** +* Checks if the URL object is relative +* +* @param url - The URL object to check +* @returns True if the URL object is relative, false otherwise +*/ +function isURLObjectRelative(url) { + return "isRelative" in url; +} +/** +* Parses string to a URL object +* +* @param url - The URL to parse +* @returns The parsed URL object or undefined if the URL is invalid +*/ +function parseStringToURLObject(url, urlBase) { + const isRelative = url.indexOf("://") <= 0 && url.indexOf("//") !== 0; + const base = urlBase ?? (isRelative ? DEFAULT_BASE_URL : void 0); + try { + if ("canParse" in URL && !URL.canParse(url, base)) return; + const fullUrlObject = new URL(url, base); + if (isRelative) return { + isRelative, + pathname: fullUrlObject.pathname, + search: fullUrlObject.search, + hash: fullUrlObject.hash + }; + return fullUrlObject; + } catch {} +} +/** +* Parses string form of URL into an object +* // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B +* // intentionally using regex and not href parsing trick because React Native and other +* // environments where DOM might not be available +* @returns parsed URL object +*/ +function parseUrl(url) { + if (!url) return {}; + const match = url.match(/^(([^:/?#]+):)?(\/\/([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?$/); + if (!match) return {}; + const query = match[6] || ""; + const fragment = match[8] || ""; + return { + host: match[4], + path: match[5], + protocol: match[2], + search: query, + hash: fragment, + relative: match[5] + query + fragment + }; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/isSentryRequestUrl.js +/** +* Checks whether given url points to Sentry server +* +* @param url url to verify +*/ +function isSentryRequestUrl(url, client$1) { + const dsn = client$1?.getDsn(); + const tunnel = client$1?.getOptions().tunnel; + return checkDsn(url, dsn) || checkTunnel(url, tunnel); +} +function checkTunnel(url, tunnel) { + if (!tunnel) return false; + return removeTrailingSlash(url) === removeTrailingSlash(tunnel); +} +function checkDsn(url, dsn) { + const urlParts = parseStringToURLObject(url); + if (!urlParts || isURLObjectRelative(urlParts)) return false; + return dsn ? urlParts.host.includes(dsn.host) && /(^|&|\?)sentry_key=/.test(urlParts.search) : false; +} +function removeTrailingSlash(str) { + return str[str.length - 1] === "/" ? str.slice(0, -1) : str; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/ipAddress.js +/** +* @internal +*/ +function addAutoIpAddressToSession(session) { + if ("aggregates" in session) { + if (session.attrs?.["ip_address"] === void 0) session.attrs = { + ...session.attrs, + ip_address: "{{auto}}" + }; + } else if (session.ipAddress === void 0) session.ipAddress = "{{auto}}"; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/sdkMetadata.js +/** +* A builder for the SDK metadata in the options for the SDK initialization. +* +* Note: This function is identical to `buildMetadata` in Remix and NextJS and SvelteKit. +* We don't extract it for bundle size reasons. +* @see https://github.com/getsentry/sentry-javascript/pull/7404 +* @see https://github.com/getsentry/sentry-javascript/pull/4196 +* +* If you make changes to this function consider updating the others as well. +* +* @param options SDK options object that gets mutated +* @param names list of package names +*/ +function applySdkMetadata(options, name, names = [name], source = "npm") { + const metadata = options._metadata || {}; + if (!metadata.sdk) metadata.sdk = { + name: `sentry.javascript.${name}`, + packages: names.map((name$1) => ({ + name: `${source}:@sentry/${name$1}`, + version: SDK_VERSION$2 + })), + version: SDK_VERSION$2 + }; + options._metadata = metadata; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/breadcrumbs.js +/** +* Default maximum number of breadcrumbs added to an event. Can be overwritten +* with {@link Options.maxBreadcrumbs}. +*/ +var DEFAULT_BREADCRUMBS = 100; +/** +* Records a new breadcrumb which will be attached to future events. +* +* Breadcrumbs will be added to subsequent events to provide more context on +* user's actions prior to an error or crash. +*/ +function addBreadcrumb(breadcrumb, hint) { + const client$1 = getClient(); + const isolationScope = getIsolationScope(); + if (!client$1) return; + const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } = client$1.getOptions(); + if (maxBreadcrumbs <= 0) return; + const mergedBreadcrumb = { + timestamp: dateTimestampInSeconds$1(), + ...breadcrumb + }; + const finalBreadcrumb = beforeBreadcrumb ? consoleSandbox$2(() => beforeBreadcrumb(mergedBreadcrumb, hint)) : mergedBreadcrumb; + if (finalBreadcrumb === null) return; + if (client$1.emit) client$1.emit("beforeAddBreadcrumb", finalBreadcrumb, hint); + isolationScope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integrations/functiontostring.js +var originalFunctionToString; +var INTEGRATION_NAME$7 = "FunctionToString"; +var SETUP_CLIENTS = /* @__PURE__ */ new WeakMap(); +var _functionToStringIntegration = (() => { + return { + name: INTEGRATION_NAME$7, + setupOnce() { + originalFunctionToString = Function.prototype.toString; + try { + Function.prototype.toString = function(...args) { + const originalFunction = getOriginalFunction(this); + const context = SETUP_CLIENTS.has(getClient()) && originalFunction !== void 0 ? originalFunction : this; + return originalFunctionToString.apply(context, args); + }; + } catch {} + }, + setup(client$1) { + SETUP_CLIENTS.set(client$1, true); + } + }; +}); +/** +* Patch toString calls to return proper name for wrapped functions. +* +* ```js +* Sentry.init({ +* integrations: [ +* functionToStringIntegration(), +* ], +* }); +* ``` +*/ +var functionToStringIntegration = defineIntegration(_functionToStringIntegration); + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/aggregate-errors.js +/** +* Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter. +*/ +function applyAggregateErrorsToEvent(exceptionFromErrorImplementation, parser, key, limit, event, hint) { + if (!event.exception?.values || !hint || !isInstanceOf$1(hint.originalException, Error)) return; + const originalException = event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : void 0; + if (originalException) event.exception.values = aggregateExceptionsFromError(exceptionFromErrorImplementation, parser, limit, hint.originalException, key, event.exception.values, originalException, 0); +} +function aggregateExceptionsFromError(exceptionFromErrorImplementation, parser, limit, error$2, key, prevExceptions, exception, exceptionId) { + if (prevExceptions.length >= limit + 1) return prevExceptions; + let newExceptions = [...prevExceptions]; + if (isInstanceOf$1(error$2[key], Error)) { + applyExceptionGroupFieldsForParentException(exception, exceptionId); + const newException = exceptionFromErrorImplementation(parser, error$2[key]); + const newExceptionId = newExceptions.length; + applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId); + newExceptions = aggregateExceptionsFromError(exceptionFromErrorImplementation, parser, limit, error$2[key], key, [newException, ...newExceptions], newException, newExceptionId); + } + if (Array.isArray(error$2.errors)) error$2.errors.forEach((childError, i) => { + if (isInstanceOf$1(childError, Error)) { + applyExceptionGroupFieldsForParentException(exception, exceptionId); + const newException = exceptionFromErrorImplementation(parser, childError); + const newExceptionId = newExceptions.length; + applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId); + newExceptions = aggregateExceptionsFromError(exceptionFromErrorImplementation, parser, limit, childError, key, [newException, ...newExceptions], newException, newExceptionId); + } + }); + return newExceptions; +} +function applyExceptionGroupFieldsForParentException(exception, exceptionId) { + exception.mechanism = { + handled: true, + type: "auto.core.linked_errors", + ...exception.mechanism, + ...exception.type === "AggregateError" && { is_exception_group: true }, + exception_id: exceptionId + }; +} +function applyExceptionGroupFieldsForChildException(exception, source, exceptionId, parentId) { + exception.mechanism = { + handled: true, + ...exception.mechanism, + type: "chained", + source, + exception_id: exceptionId, + parent_id: parentId + }; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/console.js +/** +* Add an instrumentation handler for when a console.xxx method is called. +* +* Use at your own risk, this might break without changelog notice, only used internally. +* @hidden +*/ +function addConsoleInstrumentationHandler(handler) { + const type = "console"; + addHandler$1(type, handler); + maybeInstrument$1(type, instrumentConsole); +} +function instrumentConsole() { + if (!("console" in GLOBAL_OBJ$1)) return; + CONSOLE_LEVELS.forEach(function(level) { + if (!(level in GLOBAL_OBJ$1.console)) return; + fill(GLOBAL_OBJ$1.console, level, function(originalConsoleMethod) { + originalConsoleMethods$2[level] = originalConsoleMethod; + return function(...args) { + triggerHandlers$1("console", { + args, + level + }); + originalConsoleMethods$2[level]?.apply(GLOBAL_OBJ$1.console, args); + }; + }); + }); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/severity.js +/** +* Converts a string-based level into a `SeverityLevel`, normalizing it along the way. +* +* @param level String representation of desired `SeverityLevel`. +* @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level. +*/ +function severityLevelFromString(level) { + return level === "warn" ? "warning" : [ + "fatal", + "error", + "warning", + "log", + "info", + "debug" + ].includes(level) ? level : "log"; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integrations/captureconsole.js +var INTEGRATION_NAME$6 = "CaptureConsole"; +var _captureConsoleIntegration = ((options = {}) => { + const levels = options.levels || CONSOLE_LEVELS; + const handled = options.handled ?? true; + return { + name: INTEGRATION_NAME$6, + setup(client$1) { + if (!("console" in GLOBAL_OBJ$1)) return; + addConsoleInstrumentationHandler(({ args, level }) => { + if (getClient() !== client$1 || !levels.includes(level)) return; + consoleHandler(args, level, handled); + }); + } + }; +}); +/** +* Send Console API calls as Sentry Events. +*/ +var captureConsoleIntegration = defineIntegration(_captureConsoleIntegration); +function consoleHandler(args, level, handled) { + const captureContext = { + level: severityLevelFromString(level), + extra: { arguments: args } + }; + withScope((scope) => { + scope.addEventProcessor((event) => { + event.logger = "console"; + addExceptionMechanism(event, { + handled, + type: "auto.core.capture_console" + }); + return event; + }); + if (level === "assert") { + if (!args[0]) { + const message = `Assertion failed: ${safeJoin(args.slice(1), " ") || "console.assert"}`; + scope.setExtra("arguments", args.slice(1)); + captureMessage(message, captureContext); + } + return; + } + const error$2 = args.find((arg) => arg instanceof Error); + if (error$2) { + captureException(error$2, captureContext); + return; + } + captureMessage(safeJoin(args, " "), captureContext); + }); +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integrations/dedupe.js +var INTEGRATION_NAME$5 = "Dedupe"; +var _dedupeIntegration = (() => { + let previousEvent; + return { + name: INTEGRATION_NAME$5, + processEvent(currentEvent) { + if (currentEvent.type) return currentEvent; + try { + if (_shouldDropEvent(currentEvent, previousEvent)) { + DEBUG_BUILD$3 && debug$1.warn("Event dropped due to being a duplicate of previously captured event."); + return null; + } + } catch {} + return previousEvent = currentEvent; + } + }; +}); +/** +* Deduplication filter. +*/ +var dedupeIntegration = defineIntegration(_dedupeIntegration); +/** only exported for tests. */ +function _shouldDropEvent(currentEvent, previousEvent) { + if (!previousEvent) return false; + if (_isSameMessageEvent(currentEvent, previousEvent)) return true; + if (_isSameExceptionEvent(currentEvent, previousEvent)) return true; + return false; +} +function _isSameMessageEvent(currentEvent, previousEvent) { + const currentMessage = currentEvent.message; + const previousMessage = previousEvent.message; + if (!currentMessage && !previousMessage) return false; + if (currentMessage && !previousMessage || !currentMessage && previousMessage) return false; + if (currentMessage !== previousMessage) return false; + if (!_isSameFingerprint(currentEvent, previousEvent)) return false; + if (!_isSameStacktrace(currentEvent, previousEvent)) return false; + return true; +} +function _isSameExceptionEvent(currentEvent, previousEvent) { + const previousException = _getExceptionFromEvent(previousEvent); + const currentException = _getExceptionFromEvent(currentEvent); + if (!previousException || !currentException) return false; + if (previousException.type !== currentException.type || previousException.value !== currentException.value) return false; + if (!_isSameFingerprint(currentEvent, previousEvent)) return false; + if (!_isSameStacktrace(currentEvent, previousEvent)) return false; + return true; +} +function _isSameStacktrace(currentEvent, previousEvent) { + let currentFrames = getFramesFromEvent(currentEvent); + let previousFrames = getFramesFromEvent(previousEvent); + if (!currentFrames && !previousFrames) return true; + if (currentFrames && !previousFrames || !currentFrames && previousFrames) return false; + currentFrames = currentFrames; + previousFrames = previousFrames; + if (previousFrames.length !== currentFrames.length) return false; + for (let i = 0; i < previousFrames.length; i++) { + const frameA = previousFrames[i]; + const frameB = currentFrames[i]; + if (frameA.filename !== frameB.filename || frameA.lineno !== frameB.lineno || frameA.colno !== frameB.colno || frameA.function !== frameB.function) return false; + } + return true; +} +function _isSameFingerprint(currentEvent, previousEvent) { + let currentFingerprint = currentEvent.fingerprint; + let previousFingerprint = previousEvent.fingerprint; + if (!currentFingerprint && !previousFingerprint) return true; + if (currentFingerprint && !previousFingerprint || !currentFingerprint && previousFingerprint) return false; + currentFingerprint = currentFingerprint; + previousFingerprint = previousFingerprint; + try { + return !!(currentFingerprint.join("") === previousFingerprint.join("")); + } catch { + return false; + } +} +function _getExceptionFromEvent(event) { + return event.exception?.values?.[0]; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/breadcrumb-log-level.js +/** +* Determine a breadcrumb's log level (only `warning` or `error`) based on an HTTP status code. +*/ +function getBreadcrumbLogLevelFromHttpStatusCode(statusCode) { + if (statusCode === void 0) return; + else if (statusCode >= 400 && statusCode < 500) return "warning"; + else if (statusCode >= 500) return "error"; + else return; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/supports.js +var WINDOW$4 = GLOBAL_OBJ$1; +function _isFetchSupported() { + if (!("fetch" in WINDOW$4)) return false; + try { + new Headers(); + new Request("http://www.example.com"); + new Response(); + return true; + } catch { + return false; + } +} +/** +* isNative checks if the given function is a native implementation +*/ +function isNativeFunction(func) { + return func && /^function\s+\w+\(\)\s+\{\s+\[native code\]\s+\}$/.test(func.toString()); +} +/** +* Tells whether current environment supports Fetch API natively +* {@link supportsNativeFetch}. +* +* @returns true if `window.fetch` is natively implemented, false otherwise +*/ +function supportsNativeFetch() { + if (typeof EdgeRuntime === "string") return true; + if (!_isFetchSupported()) return false; + if (isNativeFunction(WINDOW$4.fetch)) return true; + let result = false; + const doc = WINDOW$4.document; + if (doc && typeof doc.createElement === "function") try { + const sandbox = doc.createElement("iframe"); + sandbox.hidden = true; + doc.head.appendChild(sandbox); + if (sandbox.contentWindow?.fetch) result = isNativeFunction(sandbox.contentWindow.fetch); + doc.head.removeChild(sandbox); + } catch (err) { + DEBUG_BUILD$3 && debug$1.warn("Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ", err); + } + return result; +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/fetch.js +/** +* Add an instrumentation handler for when a fetch request happens. +* The handler function is called once when the request starts and once when it ends, +* which can be identified by checking if it has an `endTimestamp`. +* +* Use at your own risk, this might break without changelog notice, only used internally. +* @hidden +*/ +function addFetchInstrumentationHandler(handler, skipNativeFetchCheck) { + const type = "fetch"; + addHandler$1(type, handler); + maybeInstrument$1(type, () => instrumentFetch(void 0, skipNativeFetchCheck)); +} +function instrumentFetch(onFetchResolved, skipNativeFetchCheck = false) { + if (skipNativeFetchCheck && !supportsNativeFetch()) return; + fill(GLOBAL_OBJ$1, "fetch", function(originalFetch) { + return function(...args) { + const virtualError = /* @__PURE__ */ new Error(); + const { method, url } = parseFetchArgs(args); + const handlerData = { + args, + fetchData: { + method, + url + }, + startTimestamp: timestampInSeconds$1() * 1e3, + virtualError, + headers: getHeadersFromFetchArgs(args) + }; + if (!onFetchResolved) triggerHandlers$1("fetch", { ...handlerData }); + return originalFetch.apply(GLOBAL_OBJ$1, args).then(async (response) => { + if (onFetchResolved) onFetchResolved(response); + else triggerHandlers$1("fetch", { + ...handlerData, + endTimestamp: timestampInSeconds$1() * 1e3, + response + }); + return response; + }, (error$2) => { + triggerHandlers$1("fetch", { + ...handlerData, + endTimestamp: timestampInSeconds$1() * 1e3, + error: error$2 + }); + if (isError$1(error$2) && error$2.stack === void 0) { + error$2.stack = virtualError.stack; + addNonEnumerableProperty$1(error$2, "framesToPop", 1); + } + if (error$2 instanceof TypeError && (error$2.message === "Failed to fetch" || error$2.message === "Load failed" || error$2.message === "NetworkError when attempting to fetch resource.")) try { + const url$1 = new URL(handlerData.fetchData.url); + error$2.message = `${error$2.message} (${url$1.host})`; + } catch {} + throw error$2; + }); + }; + }); +} +function hasProp(obj, prop) { + return !!obj && typeof obj === "object" && !!obj[prop]; +} +function getUrlFromResource(resource) { + if (typeof resource === "string") return resource; + if (!resource) return ""; + if (hasProp(resource, "url")) return resource.url; + if (resource.toString) return resource.toString(); + return ""; +} +/** +* Parses the fetch arguments to find the used Http method and the url of the request. +* Exported for tests only. +*/ +function parseFetchArgs(fetchArgs) { + if (fetchArgs.length === 0) return { + method: "GET", + url: "" + }; + if (fetchArgs.length === 2) { + const [url, options] = fetchArgs; + return { + url: getUrlFromResource(url), + method: hasProp(options, "method") ? String(options.method).toUpperCase() : "GET" + }; + } + const arg = fetchArgs[0]; + return { + url: getUrlFromResource(arg), + method: hasProp(arg, "method") ? String(arg.method).toUpperCase() : "GET" + }; +} +function getHeadersFromFetchArgs(fetchArgs) { + const [requestArgument, optionsArgument] = fetchArgs; + try { + if (typeof optionsArgument === "object" && optionsArgument !== null && "headers" in optionsArgument && optionsArgument.headers) return new Headers(optionsArgument.headers); + if (isRequest(requestArgument)) return new Headers(requestArgument.headers); + } catch {} +} + +//#endregion +//#region node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/env.js +/** +* Get source of SDK. +*/ +function getSDKSource() { + return "npm"; +} + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/helpers.js +var WINDOW$1 = GLOBAL_OBJ$1; +var ignoreOnError = 0; +/** +* @hidden +*/ +function shouldIgnoreOnError() { + return ignoreOnError > 0; +} +/** +* @hidden +*/ +function ignoreNextOnError() { + ignoreOnError++; + setTimeout(() => { + ignoreOnError--; + }); +} +/** +* Instruments the given function and sends an event to Sentry every time the +* function throws an exception. +* +* @param fn A function to wrap. It is generally safe to pass an unbound function, because the returned wrapper always +* has a correct `this` context. +* @returns The wrapped function. +* @hidden +*/ +function wrap(fn, options = {}) { + function isFunction(fn$1) { + return typeof fn$1 === "function"; + } + if (!isFunction(fn)) return fn; + try { + const wrapper = fn.__sentry_wrapped__; + if (wrapper) if (typeof wrapper === "function") return wrapper; + else return fn; + if (getOriginalFunction(fn)) return fn; + } catch { + return fn; + } + const sentryWrapped = function(...args) { + try { + const wrappedArguments = args.map((arg) => wrap(arg, options)); + return fn.apply(this, wrappedArguments); + } catch (ex) { + ignoreNextOnError(); + withScope((scope) => { + scope.addEventProcessor((event) => { + if (options.mechanism) { + addExceptionTypeValue(event, void 0, void 0); + addExceptionMechanism(event, options.mechanism); + } + event.extra = { + ...event.extra, + arguments: args + }; + return event; + }); + captureException(ex); + }); + throw ex; + } + }; + try { + for (const property in fn) if (Object.prototype.hasOwnProperty.call(fn, property)) sentryWrapped[property] = fn[property]; + } catch {} + markFunctionWrapped$1(sentryWrapped, fn); + addNonEnumerableProperty$1(fn, "__sentry_wrapped__", sentryWrapped); + try { + if (Object.getOwnPropertyDescriptor(sentryWrapped, "name").configurable) Object.defineProperty(sentryWrapped, "name", { get() { + return fn.name; + } }); + } catch {} + return sentryWrapped; +} +/** +* Get HTTP request data from the current page. +*/ +function getHttpRequestData() { + const url = getLocationHref(); + const { referrer } = WINDOW$1.document || {}; + const { userAgent } = WINDOW$1.navigator || {}; + return { + url, + headers: { + ...referrer && { Referer: referrer }, + ...userAgent && { "User-Agent": userAgent } + } + }; +} + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/eventbuilder.js +/** +* This function creates an exception from a JavaScript Error +*/ +function exceptionFromError(stackParser, ex) { + const frames = parseStackFrames(stackParser, ex); + const exception = { + type: extractType(ex), + value: extractMessage(ex) + }; + if (frames.length) exception.stacktrace = { frames }; + if (exception.type === void 0 && exception.value === "") exception.value = "Unrecoverable error caught"; + return exception; +} +function eventFromPlainObject(stackParser, exception, syntheticException, isUnhandledRejection) { + const normalizeDepth = getClient()?.getOptions().normalizeDepth; + const errorFromProp = getErrorPropertyFromObject(exception); + const extra = { __serialized__: normalizeToSize(exception, normalizeDepth) }; + if (errorFromProp) return { + exception: { values: [exceptionFromError(stackParser, errorFromProp)] }, + extra + }; + const event = { + exception: { values: [{ + type: isEvent$1(exception) ? exception.constructor.name : isUnhandledRejection ? "UnhandledRejection" : "Error", + value: getNonErrorObjectExceptionValue(exception, { isUnhandledRejection }) + }] }, + extra + }; + if (syntheticException) { + const frames = parseStackFrames(stackParser, syntheticException); + if (frames.length) event.exception.values[0].stacktrace = { frames }; + } + return event; +} +function eventFromError(stackParser, ex) { + return { exception: { values: [exceptionFromError(stackParser, ex)] } }; +} +/** Parses stack frames from an error */ +function parseStackFrames(stackParser, ex) { + const stacktrace = ex.stacktrace || ex.stack || ""; + const skipLines = getSkipFirstStackStringLines(ex); + const framesToPop = getPopFirstTopFrames(ex); + try { + return stackParser(stacktrace, skipLines, framesToPop); + } catch {} + return []; +} +var reactMinifiedRegexp = /Minified React error #\d+;/i; +/** +* Certain known React errors contain links that would be falsely +* parsed as frames. This function check for these errors and +* returns number of the stack string lines to skip. +*/ +function getSkipFirstStackStringLines(ex) { + if (ex && reactMinifiedRegexp.test(ex.message)) return 1; + return 0; +} +/** +* If error has `framesToPop` property, it means that the +* creator tells us the first x frames will be useless +* and should be discarded. Typically error from wrapper function +* which don't point to the actual location in the developer's code. +* +* Example: https://github.com/zertosh/invariant/blob/master/invariant.js#L46 +*/ +function getPopFirstTopFrames(ex) { + if (typeof ex.framesToPop === "number") return ex.framesToPop; + return 0; +} +function isWebAssemblyException(exception) { + if (typeof WebAssembly !== "undefined" && typeof WebAssembly.Exception !== "undefined") return exception instanceof WebAssembly.Exception; + else return false; +} +/** +* Extracts from errors what we use as the exception `type` in error events. +* +* Usually, this is the `name` property on Error objects but WASM errors need to be treated differently. +*/ +function extractType(ex) { + const name = ex?.name; + if (!name && isWebAssemblyException(ex)) return ex.message && Array.isArray(ex.message) && ex.message.length == 2 ? ex.message[0] : "WebAssembly.Exception"; + return name; +} +/** +* There are cases where stacktrace.message is an Event object +* https://github.com/getsentry/sentry-javascript/issues/1949 +* In this specific case we try to extract stacktrace.message.error.message +*/ +function extractMessage(ex) { + const message = ex?.message; + if (isWebAssemblyException(ex)) { + if (Array.isArray(ex.message) && ex.message.length == 2) return ex.message[1]; + return "wasm exception"; + } + if (!message) return "No error message"; + if (message.error && typeof message.error.message === "string") return message.error.message; + return message; +} +/** +* Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`. +* @hidden +*/ +function eventFromException(stackParser, exception, hint, attachStacktrace) { + const event = eventFromUnknownInput(stackParser, exception, hint?.syntheticException || void 0, attachStacktrace); + addExceptionMechanism(event); + event.level = "error"; + if (hint?.event_id) event.event_id = hint.event_id; + return resolvedSyncPromise$1(event); +} +/** +* Builds and Event from a Message +* @hidden +*/ +function eventFromMessage(stackParser, message, level = "info", hint, attachStacktrace) { + const event = eventFromString(stackParser, message, hint?.syntheticException || void 0, attachStacktrace); + event.level = level; + if (hint?.event_id) event.event_id = hint.event_id; + return resolvedSyncPromise$1(event); +} +/** +* @hidden +*/ +function eventFromUnknownInput(stackParser, exception, syntheticException, attachStacktrace, isUnhandledRejection) { + let event; + if (isErrorEvent(exception) && exception.error) return eventFromError(stackParser, exception.error); + if (isDOMError(exception) || isDOMException(exception)) { + const domException = exception; + if ("stack" in exception) event = eventFromError(stackParser, exception); + else { + const name = domException.name || (isDOMError(domException) ? "DOMError" : "DOMException"); + const message = domException.message ? `${name}: ${domException.message}` : name; + event = eventFromString(stackParser, message, syntheticException, attachStacktrace); + addExceptionTypeValue(event, message); + } + if ("code" in domException) event.tags = { + ...event.tags, + "DOMException.code": `${domException.code}` + }; + return event; + } + if (isError$1(exception)) return eventFromError(stackParser, exception); + if (isPlainObject$1(exception) || isEvent$1(exception)) { + event = eventFromPlainObject(stackParser, exception, syntheticException, isUnhandledRejection); + addExceptionMechanism(event, { synthetic: true }); + return event; + } + event = eventFromString(stackParser, exception, syntheticException, attachStacktrace); + addExceptionTypeValue(event, `${exception}`, void 0); + addExceptionMechanism(event, { synthetic: true }); + return event; +} +function eventFromString(stackParser, message, syntheticException, attachStacktrace) { + const event = {}; + if (attachStacktrace && syntheticException) { + const frames = parseStackFrames(stackParser, syntheticException); + if (frames.length) event.exception = { values: [{ + value: message, + stacktrace: { frames } + }] }; + addExceptionMechanism(event, { synthetic: true }); + } + if (isParameterizedString(message)) { + const { __sentry_template_string__, __sentry_template_values__ } = message; + event.logentry = { + message: __sentry_template_string__, + params: __sentry_template_values__ + }; + return event; + } + event.message = message; + return event; +} +function getNonErrorObjectExceptionValue(exception, { isUnhandledRejection }) { + const keys = extractExceptionKeysForMessage(exception); + const captureType = isUnhandledRejection ? "promise rejection" : "exception"; + if (isErrorEvent(exception)) return `Event \`ErrorEvent\` captured as ${captureType} with message \`${exception.message}\``; + if (isEvent$1(exception)) return `Event \`${getObjectClassName(exception)}\` (type=${exception.type}) captured as ${captureType}`; + return `Object captured as ${captureType} with keys: ${keys}`; +} +function getObjectClassName(obj) { + try { + const prototype = Object.getPrototypeOf(obj); + return prototype ? prototype.constructor.name : void 0; + } catch {} +} +/** If a plain object has a property that is an `Error`, return this error. */ +function getErrorPropertyFromObject(obj) { + for (const prop in obj) if (Object.prototype.hasOwnProperty.call(obj, prop)) { + const value = obj[prop]; + if (value instanceof Error) return value; + } +} + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/client.js +/** +* A magic string that build tooling can leverage in order to inject a release value into the SDK. +*/ +/** +* The Sentry Browser SDK Client. +* +* @see BrowserOptions for documentation on configuration options. +* @see SentryClient for usage documentation. +*/ +var BrowserClient = class extends Client { + /** + * Creates a new Browser SDK instance. + * + * @param options Configuration options for this SDK. + */ + constructor(options) { + const opts = applyDefaultOptions(options); + applySdkMetadata(opts, "browser", ["browser"], WINDOW$1.SENTRY_SDK_SOURCE || getSDKSource()); + if (opts._metadata?.sdk) opts._metadata.sdk.settings = { + infer_ip: opts.sendDefaultPii ? "auto" : "never", + ...opts._metadata.sdk.settings + }; + super(opts); + const { sendDefaultPii, sendClientReports, enableLogs, _experiments } = this._options; + if (WINDOW$1.document && (sendClientReports || enableLogs || _experiments?.enableMetrics)) WINDOW$1.document.addEventListener("visibilitychange", () => { + if (WINDOW$1.document.visibilityState === "hidden") { + if (sendClientReports) this._flushOutcomes(); + if (enableLogs) _INTERNAL_flushLogsBuffer(this); + if (_experiments?.enableMetrics) _INTERNAL_flushMetricsBuffer(this); + } + }); + if (sendDefaultPii) this.on("beforeSendSession", addAutoIpAddressToSession); + } + /** + * @inheritDoc + */ + eventFromException(exception, hint) { + return eventFromException(this._options.stackParser, exception, hint, this._options.attachStacktrace); + } + /** + * @inheritDoc + */ + eventFromMessage(message, level = "info", hint) { + return eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace); + } + /** + * @inheritDoc + */ + _prepareEvent(event, hint, currentScope, isolationScope) { + event.platform = event.platform || "javascript"; + return super._prepareEvent(event, hint, currentScope, isolationScope); + } +}; +/** Exported only for tests. */ +function applyDefaultOptions(optionsArg) { + return { + release: typeof __SENTRY_RELEASE__ === "string" ? __SENTRY_RELEASE__ : WINDOW$1.SENTRY_RELEASE?.id, + sendClientReports: true, + parentSpanIsAlwaysRootSpan: true, + ...optionsArg + }; +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/debug-build.js +/** +* This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code. +* +* ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking. +*/ +var DEBUG_BUILD$2 = typeof __SENTRY_DEBUG__ === "undefined" || __SENTRY_DEBUG__; + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/worldwide.js +/** Internal global with common properties and Sentry extensions */ +/** Get's the global object for the current JavaScript runtime */ +var GLOBAL_OBJ$2 = globalThis; + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/version.js +var SDK_VERSION$1 = "10.22.0"; + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/carrier.js +/** +* Returns a global singleton contained in the global `__SENTRY__[]` object. +* +* If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory +* function and added to the `__SENTRY__` object. +* +* @param name name of the global singleton on __SENTRY__ +* @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__` +* @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value +* @returns the singleton +*/ +function getGlobalSingleton$1(name, creator, obj = GLOBAL_OBJ$2) { + const __SENTRY__ = obj.__SENTRY__ = obj.__SENTRY__ || {}; + const carrier = __SENTRY__[SDK_VERSION$1] = __SENTRY__["10.22.0"] || {}; + return carrier[name] || (carrier[name] = creator()); +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/debug-logger.js +/** Prefix for logging strings */ +var PREFIX$1 = "Sentry Logger "; +/** This may be mutated by the console instrumentation. */ +var originalConsoleMethods$1 = {}; +/** +* Temporarily disable sentry console instrumentations. +* +* @param callback The function to run against the original `console` messages +* @returns The results of the callback +*/ +function consoleSandbox$1(callback) { + if (!("console" in GLOBAL_OBJ$2)) return callback(); + const console = GLOBAL_OBJ$2.console; + const wrappedFuncs = {}; + const wrappedLevels = Object.keys(originalConsoleMethods$1); + wrappedLevels.forEach((level) => { + const originalConsoleMethod = originalConsoleMethods$1[level]; + wrappedFuncs[level] = console[level]; + console[level] = originalConsoleMethod; + }); + try { + return callback(); + } finally { + wrappedLevels.forEach((level) => { + console[level] = wrappedFuncs[level]; + }); + } +} +function enable$1() { + _getLoggerSettings$1().enabled = true; +} +function disable$1() { + _getLoggerSettings$1().enabled = false; +} +function isEnabled$1() { + return _getLoggerSettings$1().enabled; +} +function log$1(...args) { + _maybeLog$1("log", ...args); +} +function warn$1(...args) { + _maybeLog$1("warn", ...args); +} +function error$1(...args) { + _maybeLog$1("error", ...args); +} +function _maybeLog$1(level, ...args) { + if (!DEBUG_BUILD$2) return; + if (isEnabled$1()) consoleSandbox$1(() => { + GLOBAL_OBJ$2.console[level](`${PREFIX$1}[${level}]:`, ...args); + }); +} +function _getLoggerSettings$1() { + if (!DEBUG_BUILD$2) return { enabled: false }; + return getGlobalSingleton$1("loggerSettings", () => ({ enabled: false })); +} +/** +* This is a logger singleton which either logs things or no-ops if logging is not enabled. +*/ +var debug$2 = { + enable: enable$1, + disable: disable$1, + isEnabled: isEnabled$1, + log: log$1, + warn: warn$1, + error: error$1 +}; + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/stacktrace.js +var defaultFunctionName$1 = ""; +/** +* Safely extract function name from itself +*/ +function getFunctionName$2(fn) { + try { + if (!fn || typeof fn !== "function") return defaultFunctionName$1; + return fn.name || defaultFunctionName$1; + } catch { + return defaultFunctionName$1; + } +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/instrument/handlers.js +var handlers = {}; +var instrumented = {}; +/** Add a handler function. */ +function addHandler(type, handler) { + handlers[type] = handlers[type] || []; + handlers[type].push(handler); +} +/** Maybe run an instrumentation function, unless it was already called. */ +function maybeInstrument(type, instrumentFn) { + if (!instrumented[type]) { + instrumented[type] = true; + try { + instrumentFn(); + } catch (e) { + DEBUG_BUILD$2 && debug$2.error(`Error while instrumenting ${type}`, e); + } + } +} +/** Trigger handlers for a given instrumentation type. */ +function triggerHandlers(type, data) { + const typeHandlers = type && handlers[type]; + if (!typeHandlers) return; + for (const handler of typeHandlers) try { + handler(data); + } catch (e) { + DEBUG_BUILD$2 && debug$2.error(`Error while triggering instrumentation handler.\nType: ${type}\nName: ${getFunctionName$2(handler)}\nError:`, e); + } +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/is.js +var objectToString$1 = Object.prototype.toString; +/** +* Checks whether given value is an instance of the given built-in class. +* +* @param wat The value to be checked +* @param className +* @returns A boolean representing the result. +*/ +function isBuiltin$1(wat, className) { + return objectToString$1.call(wat) === `[object ${className}]`; +} +/** +* Checks whether given value's type is a string +* {@link isString}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isString$2(wat) { + return isBuiltin$1(wat, "String"); +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/object.js +/** +* Replace a method in an object with a wrapped version of itself. +* +* If the method on the passed object is not a function, the wrapper will not be applied. +* +* @param source An object that contains a method to be wrapped. +* @param name The name of the method to be wrapped. +* @param replacementFactory A higher-order function that takes the original version of the given method and returns a +* wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to +* preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, )` or `origMethod.apply(this, [])` (rather than being called directly), again to preserve `this`. +* @returns void +*/ +function fill$1(source, name, replacementFactory) { + if (!(name in source)) return; + const original = source[name]; + if (typeof original !== "function") return; + const wrapped = replacementFactory(original); + if (typeof wrapped === "function") markFunctionWrapped(wrapped, original); + try { + source[name] = wrapped; + } catch { + DEBUG_BUILD$2 && debug$2.log(`Failed to replace method "${name}" in object`, source); + } +} +/** +* Defines a non-enumerable property on the given object. +* +* @param obj The object on which to set the property +* @param name The name of the property to be set +* @param value The value to which to set the property +*/ +function addNonEnumerableProperty(obj, name, value) { + try { + Object.defineProperty(obj, name, { + value, + writable: true, + configurable: true + }); + } catch { + DEBUG_BUILD$2 && debug$2.log(`Failed to add non-enumerable property "${name}" to object`, obj); + } +} +/** +* Remembers the original function on the wrapped function and +* patches up the prototype. +* +* @param wrapped the wrapper function +* @param original the original function that gets wrapped +*/ +function markFunctionWrapped(wrapped, original) { + try { + wrapped.prototype = original.prototype = original.prototype || {}; + addNonEnumerableProperty(wrapped, "__sentry_original__", original); + } catch {} +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/misc.js +function getCrypto() { + const gbl = GLOBAL_OBJ$2; + return gbl.crypto || gbl.msCrypto; +} +var emptyUuid; +function getRandomByte() { + return Math.random() * 16; +} +/** +* UUID4 generator +* @param crypto Object that provides the crypto API. +* @returns string Generated UUID4. +*/ +function uuid4(crypto = getCrypto()) { + try { + if (crypto?.randomUUID) return crypto.randomUUID().replace(/-/g, ""); + } catch {} + if (!emptyUuid) emptyUuid = "10000000100040008000100000000000"; + return emptyUuid.replace(/[018]/g, (c) => (c ^ (getRandomByte() & 15) >> c / 4).toString(16)); +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/time.js +var ONE_SECOND_IN_MS = 1e3; +/** +* A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance} +* for accessing a high-resolution monotonic clock. +*/ +/** +* Returns a timestamp in seconds since the UNIX epoch using the Date API. +*/ +function dateTimestampInSeconds() { + return Date.now() / ONE_SECOND_IN_MS; +} +/** +* Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not +* support the API. +* +* Wrapping the native API works around differences in behavior from different browsers. +*/ +function createUnixTimestampInSecondsFunc() { + const { performance } = GLOBAL_OBJ$2; + if (!performance?.now || !performance.timeOrigin) return dateTimestampInSeconds; + const timeOrigin = performance.timeOrigin; + return () => { + return (timeOrigin + performance.now()) / ONE_SECOND_IN_MS; + }; +} +var _cachedTimestampInSeconds; +/** +* Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the +* availability of the Performance API. +* +* BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is +* asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The +* skew can grow to arbitrary amounts like days, weeks or months. +* See https://github.com/getsentry/sentry-javascript/issues/2590. +*/ +function timestampInSeconds() { + return (_cachedTimestampInSeconds ?? (_cachedTimestampInSeconds = createUnixTimestampInSecondsFunc()))(); +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/supports.js +var WINDOW$3 = GLOBAL_OBJ$2; +/** +* Tells whether current environment supports History API +* {@link supportsHistory}. +* +* @returns Answer to the given question. +*/ +function supportsHistory() { + return "history" in WINDOW$3 && !!WINDOW$3.history; +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/build/esm/types.js +var WINDOW$2 = GLOBAL_OBJ$2; + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/build/esm/instrument/dom.js +var DEBOUNCE_DURATION = 1e3; +var debounceTimerID; +var lastCapturedEventType; +var lastCapturedEventTargetId; +/** +* Add an instrumentation handler for when a click or a keypress happens. +* +* Use at your own risk, this might break without changelog notice, only used internally. +* @hidden +*/ +function addClickKeypressInstrumentationHandler(handler) { + const type = "dom"; + addHandler(type, handler); + maybeInstrument(type, instrumentDOM); +} +/** Exported for tests only. */ +function instrumentDOM() { + if (!WINDOW$2.document) return; + const triggerDOMHandler = triggerHandlers.bind(null, "dom"); + const globalDOMEventHandler = makeDOMEventHandler(triggerDOMHandler, true); + WINDOW$2.document.addEventListener("click", globalDOMEventHandler, false); + WINDOW$2.document.addEventListener("keypress", globalDOMEventHandler, false); + ["EventTarget", "Node"].forEach((target) => { + const proto = WINDOW$2[target]?.prototype; + if (!proto?.hasOwnProperty?.("addEventListener")) return; + fill$1(proto, "addEventListener", function(originalAddEventListener) { + return function(type, listener, options) { + if (type === "click" || type == "keypress") try { + const handlers$2 = this.__sentry_instrumentation_handlers__ = this.__sentry_instrumentation_handlers__ || {}; + const handlerForType = handlers$2[type] = handlers$2[type] || { refCount: 0 }; + if (!handlerForType.handler) { + const handler = makeDOMEventHandler(triggerDOMHandler); + handlerForType.handler = handler; + originalAddEventListener.call(this, type, handler, options); + } + handlerForType.refCount++; + } catch {} + return originalAddEventListener.call(this, type, listener, options); + }; + }); + fill$1(proto, "removeEventListener", function(originalRemoveEventListener) { + return function(type, listener, options) { + if (type === "click" || type == "keypress") try { + const handlers$2 = this.__sentry_instrumentation_handlers__ || {}; + const handlerForType = handlers$2[type]; + if (handlerForType) { + handlerForType.refCount--; + if (handlerForType.refCount <= 0) { + originalRemoveEventListener.call(this, type, handlerForType.handler, options); + handlerForType.handler = void 0; + delete handlers$2[type]; + } + if (Object.keys(handlers$2).length === 0) delete this.__sentry_instrumentation_handlers__; + } + } catch {} + return originalRemoveEventListener.call(this, type, listener, options); + }; + }); + }); +} +/** +* Check whether the event is similar to the last captured one. For example, two click events on the same button. +*/ +function isSimilarToLastCapturedEvent(event) { + if (event.type !== lastCapturedEventType) return false; + try { + if (!event.target || event.target._sentryId !== lastCapturedEventTargetId) return false; + } catch {} + return true; +} +/** +* Decide whether an event should be captured. +* @param event event to be captured +*/ +function shouldSkipDOMEvent(eventType, target) { + if (eventType !== "keypress") return false; + if (!target?.tagName) return true; + if (target.tagName === "INPUT" || target.tagName === "TEXTAREA" || target.isContentEditable) return false; + return true; +} +/** +* Wraps addEventListener to capture UI breadcrumbs +*/ +function makeDOMEventHandler(handler, globalListener = false) { + return (event) => { + if (!event || event["_sentryCaptured"]) return; + const target = getEventTarget(event); + if (shouldSkipDOMEvent(event.type, target)) return; + addNonEnumerableProperty(event, "_sentryCaptured", true); + if (target && !target._sentryId) addNonEnumerableProperty(target, "_sentryId", uuid4()); + const name = event.type === "keypress" ? "input" : event.type; + if (!isSimilarToLastCapturedEvent(event)) { + handler({ + event, + name, + global: globalListener + }); + lastCapturedEventType = event.type; + lastCapturedEventTargetId = target ? target._sentryId : void 0; + } + clearTimeout(debounceTimerID); + debounceTimerID = WINDOW$2.setTimeout(() => { + lastCapturedEventTargetId = void 0; + lastCapturedEventType = void 0; + }, DEBOUNCE_DURATION); + }; +} +function getEventTarget(event) { + try { + return event.target; + } catch { + return null; + } +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/build/esm/instrument/history.js +var lastHref; +/** +* Add an instrumentation handler for when a fetch request happens. +* The handler function is called once when the request starts and once when it ends, +* which can be identified by checking if it has an `endTimestamp`. +* +* Use at your own risk, this might break without changelog notice, only used internally. +* @hidden +*/ +function addHistoryInstrumentationHandler(handler) { + const type = "history"; + addHandler(type, handler); + maybeInstrument(type, instrumentHistory); +} +/** +* Exported just for testing +*/ +function instrumentHistory() { + WINDOW$2.addEventListener("popstate", () => { + const to = WINDOW$2.location.href; + const from = lastHref; + lastHref = to; + if (from === to) return; + triggerHandlers("history", { + from, + to + }); + }); + if (!supportsHistory()) return; + function historyReplacementFunction(originalHistoryFunction) { + return function(...args) { + const url = args.length > 2 ? args[2] : void 0; + if (url) { + const from = lastHref; + const to = getAbsoluteUrl(String(url)); + lastHref = to; + if (from === to) return originalHistoryFunction.apply(this, args); + triggerHandlers("history", { + from, + to + }); + } + return originalHistoryFunction.apply(this, args); + }; + } + fill$1(WINDOW$2.history, "pushState", historyReplacementFunction); + fill$1(WINDOW$2.history, "replaceState", historyReplacementFunction); +} +function getAbsoluteUrl(urlOrPath) { + try { + return new URL(urlOrPath, WINDOW$2.location.origin).toString(); + } catch { + return urlOrPath; + } +} + +//#endregion +//#region node_modules/@sentry-internal/browser-utils/build/esm/instrument/xhr.js +var SENTRY_XHR_DATA_KEY = "__sentry_xhr_v3__"; +/** +* Add an instrumentation handler for when an XHR request happens. +* The handler function is called once when the request starts and once when it ends, +* which can be identified by checking if it has an `endTimestamp`. +* +* Use at your own risk, this might break without changelog notice, only used internally. +* @hidden +*/ +function addXhrInstrumentationHandler(handler) { + const type = "xhr"; + addHandler(type, handler); + maybeInstrument(type, instrumentXHR); +} +/** Exported only for tests. */ +function instrumentXHR() { + if (!WINDOW$2.XMLHttpRequest) return; + const xhrproto = XMLHttpRequest.prototype; + xhrproto.open = new Proxy(xhrproto.open, { apply(originalOpen, xhrOpenThisArg, xhrOpenArgArray) { + const virtualError = /* @__PURE__ */ new Error(); + const startTimestamp = timestampInSeconds() * 1e3; + const method = isString$2(xhrOpenArgArray[0]) ? xhrOpenArgArray[0].toUpperCase() : void 0; + const url = parseXhrUrlArg(xhrOpenArgArray[1]); + if (!method || !url) return originalOpen.apply(xhrOpenThisArg, xhrOpenArgArray); + xhrOpenThisArg[SENTRY_XHR_DATA_KEY] = { + method, + url, + request_headers: {} + }; + if (method === "POST" && url.match(/sentry_key/)) xhrOpenThisArg.__sentry_own_request__ = true; + const onreadystatechangeHandler = () => { + const xhrInfo = xhrOpenThisArg[SENTRY_XHR_DATA_KEY]; + if (!xhrInfo) return; + if (xhrOpenThisArg.readyState === 4) { + try { + xhrInfo.status_code = xhrOpenThisArg.status; + } catch {} + triggerHandlers("xhr", { + endTimestamp: timestampInSeconds() * 1e3, + startTimestamp, + xhr: xhrOpenThisArg, + virtualError + }); + } + }; + if ("onreadystatechange" in xhrOpenThisArg && typeof xhrOpenThisArg.onreadystatechange === "function") xhrOpenThisArg.onreadystatechange = new Proxy(xhrOpenThisArg.onreadystatechange, { apply(originalOnreadystatechange, onreadystatechangeThisArg, onreadystatechangeArgArray) { + onreadystatechangeHandler(); + return originalOnreadystatechange.apply(onreadystatechangeThisArg, onreadystatechangeArgArray); + } }); + else xhrOpenThisArg.addEventListener("readystatechange", onreadystatechangeHandler); + xhrOpenThisArg.setRequestHeader = new Proxy(xhrOpenThisArg.setRequestHeader, { apply(originalSetRequestHeader, setRequestHeaderThisArg, setRequestHeaderArgArray) { + const [header, value] = setRequestHeaderArgArray; + const xhrInfo = setRequestHeaderThisArg[SENTRY_XHR_DATA_KEY]; + if (xhrInfo && isString$2(header) && isString$2(value)) xhrInfo.request_headers[header.toLowerCase()] = value; + return originalSetRequestHeader.apply(setRequestHeaderThisArg, setRequestHeaderArgArray); + } }); + return originalOpen.apply(xhrOpenThisArg, xhrOpenArgArray); + } }); + xhrproto.send = new Proxy(xhrproto.send, { apply(originalSend, sendThisArg, sendArgArray) { + const sentryXhrData = sendThisArg[SENTRY_XHR_DATA_KEY]; + if (!sentryXhrData) return originalSend.apply(sendThisArg, sendArgArray); + if (sendArgArray[0] !== void 0) sentryXhrData.body = sendArgArray[0]; + triggerHandlers("xhr", { + startTimestamp: timestampInSeconds() * 1e3, + xhr: sendThisArg + }); + return originalSend.apply(sendThisArg, sendArgArray); + } }); +} +/** +* Parses the URL argument of a XHR method to a string. +* +* See: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/open#url +* url: A string or any other object with a stringifier — including a URL object — that provides the URL of the resource to send the request to. +* +* @param url - The URL argument of an XHR method +* @returns The parsed URL string or undefined if the URL is invalid +*/ +function parseXhrUrlArg(url) { + if (isString$2(url)) return url; + try { + return url.toString(); + } catch {} +} + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/stack-parsers.js +var CHROME_PRIORITY = 30; +var GECKO_PRIORITY = 50; +function createFrame(filename, func, lineno, colno) { + const frame = { + filename, + function: func === "" ? "?" : func, + in_app: true + }; + if (lineno !== void 0) frame.lineno = lineno; + if (colno !== void 0) frame.colno = colno; + return frame; +} +var chromeRegexNoFnName = /^\s*at (\S+?)(?::(\d+))(?::(\d+))\s*$/i; +var chromeRegex = /^\s*at (?:(.+?\)(?: \[.+\])?|.*?) ?\((?:address at )?)?(?:async )?((?:|[-a-z]+:|.*bundle|\/)?.*?)(?::(\d+))?(?::(\d+))?\)?\s*$/i; +var chromeEvalRegex = /\((\S*)(?::(\d+))(?::(\d+))\)/; +var chromeDataUriRegex = /at (.+?) ?\(data:(.+?),/; +var chromeStackParserFn = (line) => { + const dataUriMatch = line.match(chromeDataUriRegex); + if (dataUriMatch) return { + filename: ``, + function: dataUriMatch[1] + }; + const noFnParts = chromeRegexNoFnName.exec(line); + if (noFnParts) { + const [, filename, line$1, col] = noFnParts; + return createFrame(filename, "?", +line$1, +col); + } + const parts = chromeRegex.exec(line); + if (parts) { + if (parts[2] && parts[2].indexOf("eval") === 0) { + const subMatch = chromeEvalRegex.exec(parts[2]); + if (subMatch) { + parts[2] = subMatch[1]; + parts[3] = subMatch[2]; + parts[4] = subMatch[3]; + } + } + const [func, filename] = extractSafariExtensionDetails(parts[1] || "?", parts[2]); + return createFrame(filename, func, parts[3] ? +parts[3] : void 0, parts[4] ? +parts[4] : void 0); + } +}; +var chromeStackLineParser = [CHROME_PRIORITY, chromeStackParserFn]; +var geckoREgex = /^\s*(.*?)(?:\((.*?)\))?(?:^|@)?((?:[-a-z]+)?:\/.*?|\[native code\]|[^@]*(?:bundle|\d+\.js)|\/[\w\-. /=]+)(?::(\d+))?(?::(\d+))?\s*$/i; +var geckoEvalRegex = /(\S+) line (\d+)(?: > eval line \d+)* > eval/i; +var gecko = (line) => { + const parts = geckoREgex.exec(line); + if (parts) { + if (parts[3] && parts[3].indexOf(" > eval") > -1) { + const subMatch = geckoEvalRegex.exec(parts[3]); + if (subMatch) { + parts[1] = parts[1] || "eval"; + parts[3] = subMatch[1]; + parts[4] = subMatch[2]; + parts[5] = ""; + } + } + let filename = parts[3]; + let func = parts[1] || "?"; + [func, filename] = extractSafariExtensionDetails(func, filename); + return createFrame(filename, func, parts[4] ? +parts[4] : void 0, parts[5] ? +parts[5] : void 0); + } +}; +var geckoStackLineParser = [GECKO_PRIORITY, gecko]; +var defaultStackLineParsers = [chromeStackLineParser, geckoStackLineParser]; +var defaultStackParser = createStackParser(...defaultStackLineParsers); +/** +* Safari web extensions, starting version unknown, can produce "frames-only" stacktraces. +* What it means, is that instead of format like: +* +* Error: wat +* at function@url:row:col +* at function@url:row:col +* at function@url:row:col +* +* it produces something like: +* +* function@url:row:col +* function@url:row:col +* function@url:row:col +* +* Because of that, it won't be captured by `chrome` RegExp and will fall into `Gecko` branch. +* This function is extracted so that we can use it in both places without duplicating the logic. +* Unfortunately "just" changing RegExp is too complicated now and making it pass all tests +* and fix this case seems like an impossible, or at least way too time-consuming task. +*/ +var extractSafariExtensionDetails = (func, filename) => { + const isSafariExtension = func.indexOf("safari-extension") !== -1; + const isSafariWebExtension = func.indexOf("safari-web-extension") !== -1; + return isSafariExtension || isSafariWebExtension ? [func.indexOf("@") !== -1 ? func.split("@")[0] : "?", isSafariExtension ? `safari-extension:${filename}` : `safari-web-extension:${filename}`] : [func, filename]; +}; + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/debug-build.js +/** +* This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code. +* +* ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking. +*/ +var DEBUG_BUILD$1 = typeof __SENTRY_DEBUG__ === "undefined" || __SENTRY_DEBUG__; + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/integrations/breadcrumbs.js +/** maxStringLength gets capped to prevent 100 breadcrumbs exceeding 1MB event payload size */ +var MAX_ALLOWED_STRING_LENGTH = 1024; +var INTEGRATION_NAME$4 = "Breadcrumbs"; +var _breadcrumbsIntegration = ((options = {}) => { + const _options = { + console: true, + dom: true, + fetch: true, + history: true, + sentry: true, + xhr: true, + ...options + }; + return { + name: INTEGRATION_NAME$4, + setup(client$1) { + if (_options.console) addConsoleInstrumentationHandler(_getConsoleBreadcrumbHandler(client$1)); + if (_options.dom) addClickKeypressInstrumentationHandler(_getDomBreadcrumbHandler(client$1, _options.dom)); + if (_options.xhr) addXhrInstrumentationHandler(_getXhrBreadcrumbHandler(client$1)); + if (_options.fetch) addFetchInstrumentationHandler(_getFetchBreadcrumbHandler(client$1)); + if (_options.history) addHistoryInstrumentationHandler(_getHistoryBreadcrumbHandler(client$1)); + if (_options.sentry) client$1.on("beforeSendEvent", _getSentryBreadcrumbHandler(client$1)); + } + }; +}); +var breadcrumbsIntegration = defineIntegration(_breadcrumbsIntegration); +/** +* Adds a breadcrumb for Sentry events or transactions if this option is enabled. +*/ +function _getSentryBreadcrumbHandler(client$1) { + return function addSentryBreadcrumb(event) { + if (getClient() !== client$1) return; + addBreadcrumb({ + category: `sentry.${event.type === "transaction" ? "transaction" : "event"}`, + event_id: event.event_id, + level: event.level, + message: getEventDescription(event) + }, { event }); + }; +} +/** +* A HOC that creates a function that creates breadcrumbs from DOM API calls. +* This is a HOC so that we get access to dom options in the closure. +*/ +function _getDomBreadcrumbHandler(client$1, dom) { + return function _innerDomBreadcrumb(handlerData) { + if (getClient() !== client$1) return; + let target; + let componentName; + let keyAttrs = typeof dom === "object" ? dom.serializeAttribute : void 0; + let maxStringLength = typeof dom === "object" && typeof dom.maxStringLength === "number" ? dom.maxStringLength : void 0; + if (maxStringLength && maxStringLength > MAX_ALLOWED_STRING_LENGTH) { + DEBUG_BUILD$1 && debug$1.warn(`\`dom.maxStringLength\` cannot exceed ${MAX_ALLOWED_STRING_LENGTH}, but a value of ${maxStringLength} was configured. Sentry will use ${MAX_ALLOWED_STRING_LENGTH} instead.`); + maxStringLength = MAX_ALLOWED_STRING_LENGTH; + } + if (typeof keyAttrs === "string") keyAttrs = [keyAttrs]; + try { + const event = handlerData.event; + const element = _isEvent(event) ? event.target : event; + target = htmlTreeAsString$1(element, { + keyAttrs, + maxStringLength + }); + componentName = getComponentName(element); + } catch { + target = ""; + } + if (target.length === 0) return; + const breadcrumb = { + category: `ui.${handlerData.name}`, + message: target + }; + if (componentName) breadcrumb.data = { "ui.component_name": componentName }; + addBreadcrumb(breadcrumb, { + event: handlerData.event, + name: handlerData.name, + global: handlerData.global + }); + }; +} +/** +* Creates breadcrumbs from console API calls +*/ +function _getConsoleBreadcrumbHandler(client$1) { + return function _consoleBreadcrumb(handlerData) { + if (getClient() !== client$1) return; + const breadcrumb = { + category: "console", + data: { + arguments: handlerData.args, + logger: "console" + }, + level: severityLevelFromString(handlerData.level), + message: safeJoin(handlerData.args, " ") + }; + if (handlerData.level === "assert") if (handlerData.args[0] === false) { + breadcrumb.message = `Assertion failed: ${safeJoin(handlerData.args.slice(1), " ") || "console.assert"}`; + breadcrumb.data.arguments = handlerData.args.slice(1); + } else return; + addBreadcrumb(breadcrumb, { + input: handlerData.args, + level: handlerData.level + }); + }; +} +/** +* Creates breadcrumbs from XHR API calls +*/ +function _getXhrBreadcrumbHandler(client$1) { + return function _xhrBreadcrumb(handlerData) { + if (getClient() !== client$1) return; + const { startTimestamp, endTimestamp } = handlerData; + const sentryXhrData = handlerData.xhr[SENTRY_XHR_DATA_KEY]; + if (!startTimestamp || !endTimestamp || !sentryXhrData) return; + const { method, url, status_code, body } = sentryXhrData; + const data = { + method, + url, + status_code + }; + const hint = { + xhr: handlerData.xhr, + input: body, + startTimestamp, + endTimestamp + }; + const breadcrumb = { + category: "xhr", + data, + type: "http", + level: getBreadcrumbLogLevelFromHttpStatusCode(status_code) + }; + client$1.emit("beforeOutgoingRequestBreadcrumb", breadcrumb, hint); + addBreadcrumb(breadcrumb, hint); + }; +} +/** +* Creates breadcrumbs from fetch API calls +*/ +function _getFetchBreadcrumbHandler(client$1) { + return function _fetchBreadcrumb(handlerData) { + if (getClient() !== client$1) return; + const { startTimestamp, endTimestamp } = handlerData; + if (!endTimestamp) return; + if (handlerData.fetchData.url.match(/sentry_key/) && handlerData.fetchData.method === "POST") return; + handlerData.fetchData.method, handlerData.fetchData.url; + if (handlerData.error) { + const data = handlerData.fetchData; + const hint = { + data: handlerData.error, + input: handlerData.args, + startTimestamp, + endTimestamp + }; + const breadcrumb = { + category: "fetch", + data, + level: "error", + type: "http" + }; + client$1.emit("beforeOutgoingRequestBreadcrumb", breadcrumb, hint); + addBreadcrumb(breadcrumb, hint); + } else { + const response = handlerData.response; + const data = { + ...handlerData.fetchData, + status_code: response?.status + }; + handlerData.fetchData.request_body_size; + handlerData.fetchData.response_body_size; + response?.status; + const hint = { + input: handlerData.args, + response, + startTimestamp, + endTimestamp + }; + const breadcrumb = { + category: "fetch", + data, + type: "http", + level: getBreadcrumbLogLevelFromHttpStatusCode(data.status_code) + }; + client$1.emit("beforeOutgoingRequestBreadcrumb", breadcrumb, hint); + addBreadcrumb(breadcrumb, hint); + } + }; +} +/** +* Creates breadcrumbs from history API calls +*/ +function _getHistoryBreadcrumbHandler(client$1) { + return function _historyBreadcrumb(handlerData) { + if (getClient() !== client$1) return; + let from = handlerData.from; + let to = handlerData.to; + const parsedLoc = parseUrl(WINDOW$1.location.href); + let parsedFrom = from ? parseUrl(from) : void 0; + const parsedTo = parseUrl(to); + if (!parsedFrom?.path) parsedFrom = parsedLoc; + if (parsedLoc.protocol === parsedTo.protocol && parsedLoc.host === parsedTo.host) to = parsedTo.relative; + if (parsedLoc.protocol === parsedFrom.protocol && parsedLoc.host === parsedFrom.host) from = parsedFrom.relative; + addBreadcrumb({ + category: "navigation", + data: { + from, + to + } + }); + }; +} +function _isEvent(event) { + return !!event && !!event.target; +} + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/integrations/browserapierrors.js +var DEFAULT_EVENT_TARGET = [ + "EventTarget", + "Window", + "Node", + "ApplicationCache", + "AudioTrackList", + "BroadcastChannel", + "ChannelMergerNode", + "CryptoOperation", + "EventSource", + "FileReader", + "HTMLUnknownElement", + "IDBDatabase", + "IDBRequest", + "IDBTransaction", + "KeyOperation", + "MediaController", + "MessagePort", + "ModalWindow", + "Notification", + "SVGElementInstance", + "Screen", + "SharedWorker", + "TextTrack", + "TextTrackCue", + "TextTrackList", + "WebSocket", + "WebSocketWorker", + "Worker", + "XMLHttpRequest", + "XMLHttpRequestEventTarget", + "XMLHttpRequestUpload" +]; +var INTEGRATION_NAME$3 = "BrowserApiErrors"; +var _browserApiErrorsIntegration = ((options = {}) => { + const _options = { + XMLHttpRequest: true, + eventTarget: true, + requestAnimationFrame: true, + setInterval: true, + setTimeout: true, + unregisterOriginalCallbacks: false, + ...options + }; + return { + name: INTEGRATION_NAME$3, + setupOnce() { + if (_options.setTimeout) fill(WINDOW$1, "setTimeout", _wrapTimeFunction); + if (_options.setInterval) fill(WINDOW$1, "setInterval", _wrapTimeFunction); + if (_options.requestAnimationFrame) fill(WINDOW$1, "requestAnimationFrame", _wrapRAF); + if (_options.XMLHttpRequest && "XMLHttpRequest" in WINDOW$1) fill(XMLHttpRequest.prototype, "send", _wrapXHR$1); + const eventTargetOption = _options.eventTarget; + if (eventTargetOption) (Array.isArray(eventTargetOption) ? eventTargetOption : DEFAULT_EVENT_TARGET).forEach((target) => _wrapEventTarget(target, _options)); + } + }; +}); +/** +* Wrap timer functions and event targets to catch errors and provide better meta data. +*/ +var browserApiErrorsIntegration = defineIntegration(_browserApiErrorsIntegration); +function _wrapTimeFunction(original) { + return function(...args) { + const originalCallback = args[0]; + args[0] = wrap(originalCallback, { mechanism: { + handled: false, + type: `auto.browser.browserapierrors.${getFunctionName$1(original)}` + } }); + return original.apply(this, args); + }; +} +function _wrapRAF(original) { + return function(callback) { + return original.apply(this, [wrap(callback, { mechanism: { + data: { handler: getFunctionName$1(original) }, + handled: false, + type: "auto.browser.browserapierrors.requestAnimationFrame" + } })]); + }; +} +function _wrapXHR$1(originalSend) { + return function(...args) { + const xhr = this; + [ + "onload", + "onerror", + "onprogress", + "onreadystatechange" + ].forEach((prop) => { + if (prop in xhr && typeof xhr[prop] === "function") fill(xhr, prop, function(original) { + const wrapOptions = { mechanism: { + data: { handler: getFunctionName$1(original) }, + handled: false, + type: `auto.browser.browserapierrors.xhr.${prop}` + } }; + const originalFunction = getOriginalFunction(original); + if (originalFunction) wrapOptions.mechanism.data.handler = getFunctionName$1(originalFunction); + return wrap(original, wrapOptions); + }); + }); + return originalSend.apply(this, args); + }; +} +function _wrapEventTarget(target, integrationOptions) { + const proto = WINDOW$1[target]?.prototype; + if (!proto?.hasOwnProperty?.("addEventListener")) return; + fill(proto, "addEventListener", function(original) { + return function(eventName, fn, options) { + try { + if (isEventListenerObject(fn)) fn.handleEvent = wrap(fn.handleEvent, { mechanism: { + data: { + handler: getFunctionName$1(fn), + target + }, + handled: false, + type: "auto.browser.browserapierrors.handleEvent" + } }); + } catch {} + if (integrationOptions.unregisterOriginalCallbacks) unregisterOriginalCallback(this, eventName, fn); + return original.apply(this, [ + eventName, + wrap(fn, { mechanism: { + data: { + handler: getFunctionName$1(fn), + target + }, + handled: false, + type: "auto.browser.browserapierrors.addEventListener" + } }), + options + ]); + }; + }); + fill(proto, "removeEventListener", function(originalRemoveEventListener) { + return function(eventName, fn, options) { + /** + * There are 2 possible scenarios here: + * + * 1. Someone passes a callback, which was attached prior to Sentry initialization, or by using unmodified + * method, eg. `document.addEventListener.call(el, name, handler). In this case, we treat this function + * as a pass-through, and call original `removeEventListener` with it. + * + * 2. Someone passes a callback, which was attached after Sentry was initialized, which means that it was using + * our wrapped version of `addEventListener`, which internally calls `wrap` helper. + * This helper "wraps" whole callback inside a try/catch statement, and attached appropriate metadata to it, + * in order for us to make a distinction between wrapped/non-wrapped functions possible. + * If a function was wrapped, it has additional property of `__sentry_wrapped__`, holding the handler. + * + * When someone adds a handler prior to initialization, and then do it again, but after, + * then we have to detach both of them. Otherwise, if we'd detach only wrapped one, it'd be impossible + * to get rid of the initial handler and it'd stick there forever. + */ + try { + const originalEventHandler = fn.__sentry_wrapped__; + if (originalEventHandler) originalRemoveEventListener.call(this, eventName, originalEventHandler, options); + } catch {} + return originalRemoveEventListener.call(this, eventName, fn, options); + }; + }); +} +function isEventListenerObject(obj) { + return typeof obj.handleEvent === "function"; +} +function unregisterOriginalCallback(target, eventName, fn) { + if (target && typeof target === "object" && "removeEventListener" in target && typeof target.removeEventListener === "function") target.removeEventListener(eventName, fn); +} + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/integrations/globalhandlers.js +var INTEGRATION_NAME$2 = "GlobalHandlers"; +var _globalHandlersIntegration = ((options = {}) => { + const _options = { + onerror: true, + onunhandledrejection: true, + ...options + }; + return { + name: INTEGRATION_NAME$2, + setupOnce() { + Error.stackTraceLimit = 50; + }, + setup(client$1) { + if (_options.onerror) { + _installGlobalOnErrorHandler(client$1); + globalHandlerLog("onerror"); + } + if (_options.onunhandledrejection) { + _installGlobalOnUnhandledRejectionHandler(client$1); + globalHandlerLog("onunhandledrejection"); + } + } + }; +}); +var globalHandlersIntegration = defineIntegration(_globalHandlersIntegration); +function _installGlobalOnErrorHandler(client$1) { + addGlobalErrorInstrumentationHandler((data) => { + const { stackParser, attachStacktrace } = getOptions(); + if (getClient() !== client$1 || shouldIgnoreOnError()) return; + const { msg, url, line, column, error: error$2 } = data; + const event = _enhanceEventWithInitialFrame(eventFromUnknownInput(stackParser, error$2 || msg, void 0, attachStacktrace, false), url, line, column); + event.level = "error"; + captureEvent(event, { + originalException: error$2, + mechanism: { + handled: false, + type: "auto.browser.global_handlers.onerror" + } + }); + }); +} +function _installGlobalOnUnhandledRejectionHandler(client$1) { + addGlobalUnhandledRejectionInstrumentationHandler((e) => { + const { stackParser, attachStacktrace } = getOptions(); + if (getClient() !== client$1 || shouldIgnoreOnError()) return; + const error$2 = _getUnhandledRejectionError(e); + const event = isPrimitive$1(error$2) ? _eventFromRejectionWithPrimitive(error$2) : eventFromUnknownInput(stackParser, error$2, void 0, attachStacktrace, true); + event.level = "error"; + captureEvent(event, { + originalException: error$2, + mechanism: { + handled: false, + type: "auto.browser.global_handlers.onunhandledrejection" + } + }); + }); +} +function _getUnhandledRejectionError(error$2) { + if (isPrimitive$1(error$2)) return error$2; + try { + if ("reason" in error$2) return error$2.reason; + if ("detail" in error$2 && "reason" in error$2.detail) return error$2.detail.reason; + } catch {} + return error$2; +} +/** +* Create an event from a promise rejection where the `reason` is a primitive. +* +* @param reason: The `reason` property of the promise rejection +* @returns An Event object with an appropriate `exception` value +*/ +function _eventFromRejectionWithPrimitive(reason) { + return { exception: { values: [{ + type: "UnhandledRejection", + value: `Non-Error promise rejection captured with value: ${String(reason)}` + }] } }; +} +function _enhanceEventWithInitialFrame(event, url, line, column) { + const e = event.exception = event.exception || {}; + const ev = e.values = e.values || []; + const ev0 = ev[0] = ev[0] || {}; + const ev0s = ev0.stacktrace = ev0.stacktrace || {}; + const ev0sf = ev0s.frames = ev0s.frames || []; + const colno = column; + const lineno = line; + const filename = getFilenameFromUrl(url) ?? getLocationHref(); + if (ev0sf.length === 0) ev0sf.push({ + colno, + filename, + function: "?", + in_app: true, + lineno + }); + return event; +} +function globalHandlerLog(type) { + DEBUG_BUILD$1 && debug$1.log(`Global Handler attached: ${type}`); +} +function getOptions() { + return getClient()?.getOptions() || { + stackParser: () => [], + attachStacktrace: false + }; +} +function getFilenameFromUrl(url) { + if (!isString$1(url) || url.length === 0) return; + if (url.startsWith("data:")) { + const match = url.match(/^data:([^;]+)/); + return ``; + } + return url.slice(0, 1024); +} + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/integrations/httpcontext.js +/** +* Collects information about HTTP request headers and +* attaches them to the event. +*/ +var httpContextIntegration = defineIntegration(() => { + return { + name: "HttpContext", + preprocessEvent(event) { + if (!WINDOW$1.navigator && !WINDOW$1.location && !WINDOW$1.document) return; + const reqData = getHttpRequestData(); + const headers = { + ...reqData.headers, + ...event.request?.headers + }; + event.request = { + ...reqData, + ...event.request, + headers + }; + } + }; +}); + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/integrations/linkederrors.js +var DEFAULT_KEY = "cause"; +var DEFAULT_LIMIT = 5; +var INTEGRATION_NAME$1 = "LinkedErrors"; +var _linkedErrorsIntegration = ((options = {}) => { + const limit = options.limit || DEFAULT_LIMIT; + const key = options.key || DEFAULT_KEY; + return { + name: INTEGRATION_NAME$1, + preprocessEvent(event, hint, client$1) { + applyAggregateErrorsToEvent(exceptionFromError, client$1.getOptions().stackParser, key, limit, event, hint); + } + }; +}); +/** +* Aggregrate linked errors in an event. +*/ +var linkedErrorsIntegration = defineIntegration(_linkedErrorsIntegration); + +//#endregion +//#region node_modules/@sentry/browser/build/npm/esm/integrations/httpclient.js +var INTEGRATION_NAME = "HttpClient"; +var _httpClientIntegration = ((options = {}) => { + const _options = { + failedRequestStatusCodes: [[500, 599]], + failedRequestTargets: [/.*/], + ...options + }; + return { + name: INTEGRATION_NAME, + setup(client$1) { + _wrapFetch(client$1, _options); + _wrapXHR(client$1, _options); + } + }; +}); +/** +* Create events for failed client side HTTP requests. +*/ +var httpClientIntegration = defineIntegration(_httpClientIntegration); +/** +* Interceptor function for fetch requests +* +* @param requestInfo The Fetch API request info +* @param response The Fetch API response +* @param requestInit The request init object +*/ +function _fetchResponseHandler(options, requestInfo, response, requestInit, error$2) { + if (_shouldCaptureResponse(options, response.status, response.url)) { + const request = _getRequest(requestInfo, requestInit); + let requestHeaders, responseHeaders, requestCookies, responseCookies; + if (_shouldSendDefaultPii()) { + [requestHeaders, requestCookies] = _parseCookieHeaders("Cookie", request); + [responseHeaders, responseCookies] = _parseCookieHeaders("Set-Cookie", response); + } + captureEvent(_createEvent({ + url: request.url, + method: request.method, + status: response.status, + requestHeaders, + responseHeaders, + requestCookies, + responseCookies, + error: error$2, + type: "fetch" + })); + } +} +function _parseCookieHeaders(cookieHeader, obj) { + const headers = _extractFetchHeaders(obj.headers); + let cookies; + try { + const cookieString = headers[cookieHeader] || headers[cookieHeader.toLowerCase()] || void 0; + if (cookieString) cookies = _parseCookieString(cookieString); + } catch {} + return [headers, cookies]; +} +/** +* Interceptor function for XHR requests +* +* @param xhr The XHR request +* @param method The HTTP method +* @param headers The HTTP headers +*/ +function _xhrResponseHandler(options, xhr, method, headers, error$2) { + if (_shouldCaptureResponse(options, xhr.status, xhr.responseURL)) { + let requestHeaders, responseCookies, responseHeaders; + if (_shouldSendDefaultPii()) { + try { + const cookieString = xhr.getResponseHeader("Set-Cookie") || xhr.getResponseHeader("set-cookie") || void 0; + if (cookieString) responseCookies = _parseCookieString(cookieString); + } catch {} + try { + responseHeaders = _getXHRResponseHeaders(xhr); + } catch {} + requestHeaders = headers; + } + captureEvent(_createEvent({ + url: xhr.responseURL, + method, + status: xhr.status, + requestHeaders, + responseHeaders, + responseCookies, + error: error$2, + type: "xhr" + })); + } +} +/** +* Extracts response size from `Content-Length` header when possible +* +* @param headers +* @returns The response size in bytes or undefined +*/ +function _getResponseSizeFromHeaders(headers) { + if (headers) { + const contentLength = headers["Content-Length"] || headers["content-length"]; + if (contentLength) return parseInt(contentLength, 10); + } +} +/** +* Creates an object containing cookies from the given cookie string +* +* @param cookieString The cookie string to parse +* @returns The parsed cookies +*/ +function _parseCookieString(cookieString) { + return cookieString.split("; ").reduce((acc, cookie) => { + const [key, value] = cookie.split("="); + if (key && value) acc[key] = value; + return acc; + }, {}); +} +/** +* Extracts the headers as an object from the given Fetch API request or response object +* +* @param headers The headers to extract +* @returns The extracted headers as an object +*/ +function _extractFetchHeaders(headers) { + const result = {}; + headers.forEach((value, key) => { + result[key] = value; + }); + return result; +} +/** +* Extracts the response headers as an object from the given XHR object +* +* @param xhr The XHR object to extract the response headers from +* @returns The response headers as an object +*/ +function _getXHRResponseHeaders(xhr) { + const headers = xhr.getAllResponseHeaders(); + if (!headers) return {}; + return headers.split("\r\n").reduce((acc, line) => { + const [key, value] = line.split(": "); + if (key && value) acc[key] = value; + return acc; + }, {}); +} +/** +* Checks if the given target url is in the given list of targets +* +* @param target The target url to check +* @returns true if the target url is in the given list of targets, false otherwise +*/ +function _isInGivenRequestTargets(failedRequestTargets, target) { + return failedRequestTargets.some((givenRequestTarget) => { + if (typeof givenRequestTarget === "string") return target.includes(givenRequestTarget); + return givenRequestTarget.test(target); + }); +} +/** +* Checks if the given status code is in the given range +* +* @param status The status code to check +* @returns true if the status code is in the given range, false otherwise +*/ +function _isInGivenStatusRanges(failedRequestStatusCodes, status) { + return failedRequestStatusCodes.some((range) => { + if (typeof range === "number") return range === status; + return status >= range[0] && status <= range[1]; + }); +} +/** +* Wraps `fetch` function to capture request and response data +*/ +function _wrapFetch(client$1, options) { + if (!supportsNativeFetch()) return; + addFetchInstrumentationHandler((handlerData) => { + if (getClient() !== client$1) return; + const { response, args, error: error$2, virtualError } = handlerData; + const [requestInfo, requestInit] = args; + if (!response) return; + _fetchResponseHandler(options, requestInfo, response, requestInit, error$2 || virtualError); + }, false); +} +/** +* Wraps XMLHttpRequest to capture request and response data +*/ +function _wrapXHR(client$1, options) { + if (!("XMLHttpRequest" in GLOBAL_OBJ$1)) return; + addXhrInstrumentationHandler((handlerData) => { + if (getClient() !== client$1) return; + const { error: error$2, virtualError } = handlerData; + const xhr = handlerData.xhr; + const sentryXhrData = xhr[SENTRY_XHR_DATA_KEY]; + if (!sentryXhrData) return; + const { method, request_headers: headers } = sentryXhrData; + try { + _xhrResponseHandler(options, xhr, method, headers, error$2 || virtualError); + } catch (e) { + DEBUG_BUILD$1 && debug$1.warn("Error while extracting response event form XHR response", e); + } + }); +} +/** +* Checks whether to capture given response as an event +* +* @param status response status code +* @param url response url +*/ +function _shouldCaptureResponse(options, status, url) { + return _isInGivenStatusRanges(options.failedRequestStatusCodes, status) && _isInGivenRequestTargets(options.failedRequestTargets, url) && !isSentryRequestUrl(url, getClient()); +} +/** +* Creates a synthetic Sentry event from given response data +* +* @param data response data +* @returns event +*/ +function _createEvent(data) { + const client$1 = getClient(); + const virtualStackTrace = client$1 && data.error && data.error instanceof Error ? data.error.stack : void 0; + const stack = virtualStackTrace && client$1 ? client$1.getOptions().stackParser(virtualStackTrace, 0, 1) : void 0; + const message = `HTTP Client Error with status code: ${data.status}`; + const event = { + message, + exception: { values: [{ + type: "Error", + value: message, + stacktrace: stack ? { frames: stack } : void 0 + }] }, + request: { + url: data.url, + method: data.method, + headers: data.requestHeaders, + cookies: data.requestCookies + }, + contexts: { response: { + status_code: data.status, + headers: data.responseHeaders, + cookies: data.responseCookies, + body_size: _getResponseSizeFromHeaders(data.responseHeaders) + } } + }; + addExceptionMechanism(event, { + type: `auto.http.client.${data.type}`, + handled: false + }); + return event; +} +function _getRequest(requestInfo, requestInit) { + if (!requestInit && requestInfo instanceof Request) return requestInfo; + if (requestInfo instanceof Request && requestInfo.bodyUsed) return requestInfo; + return new Request(requestInfo, requestInit); +} +function _shouldSendDefaultPii() { + const client$1 = getClient(); + return client$1 ? Boolean(client$1.getOptions().sendDefaultPii) : false; +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/debug-build.js +/** +* This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code. +* +* ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking. +*/ +var DEBUG_BUILD = typeof __SENTRY_DEBUG__ === "undefined" || __SENTRY_DEBUG__; + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/worldwide.js +/** Internal global with common properties and Sentry extensions */ +/** Get's the global object for the current JavaScript runtime */ +var GLOBAL_OBJ = globalThis; + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/version.js +var SDK_VERSION = "9.46.0"; + +//#endregion +//#region node_modules/@sentry/core/build/esm/carrier.js +/** Will either get the existing sentry carrier, or create a new one. */ +function getSentryCarrier(carrier) { + const __SENTRY__ = carrier.__SENTRY__ = carrier.__SENTRY__ || {}; + __SENTRY__.version = __SENTRY__.version || "9.46.0"; + return __SENTRY__[SDK_VERSION] = __SENTRY__["9.46.0"] || {}; +} +/** +* Returns a global singleton contained in the global `__SENTRY__[]` object. +* +* If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory +* function and added to the `__SENTRY__` object. +* +* @param name name of the global singleton on __SENTRY__ +* @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__` +* @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value +* @returns the singleton +*/ +function getGlobalSingleton(name, creator, obj = GLOBAL_OBJ) { + const __SENTRY__ = obj.__SENTRY__ = obj.__SENTRY__ || {}; + const carrier = __SENTRY__[SDK_VERSION] = __SENTRY__["9.46.0"] || {}; + return carrier[name] || (carrier[name] = creator()); +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/debug-logger.js +/** Prefix for logging strings */ +var PREFIX = "Sentry Logger "; +/** This may be mutated by the console instrumentation. */ +var originalConsoleMethods = {}; +/** +* Temporarily disable sentry console instrumentations. +* +* @param callback The function to run against the original `console` messages +* @returns The results of the callback +*/ +function consoleSandbox(callback) { + if (!("console" in GLOBAL_OBJ)) return callback(); + const console = GLOBAL_OBJ.console; + const wrappedFuncs = {}; + const wrappedLevels = Object.keys(originalConsoleMethods); + wrappedLevels.forEach((level) => { + const originalConsoleMethod = originalConsoleMethods[level]; + wrappedFuncs[level] = console[level]; + console[level] = originalConsoleMethod; + }); + try { + return callback(); + } finally { + wrappedLevels.forEach((level) => { + console[level] = wrappedFuncs[level]; + }); + } +} +function enable() { + _getLoggerSettings().enabled = true; +} +function disable() { + _getLoggerSettings().enabled = false; +} +function isEnabled() { + return _getLoggerSettings().enabled; +} +function log(...args) { + _maybeLog("log", ...args); +} +function warn(...args) { + _maybeLog("warn", ...args); +} +function error(...args) { + _maybeLog("error", ...args); +} +function _maybeLog(level, ...args) { + if (!DEBUG_BUILD) return; + if (isEnabled()) consoleSandbox(() => { + GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args); + }); +} +function _getLoggerSettings() { + if (!DEBUG_BUILD) return { enabled: false }; + return getGlobalSingleton("loggerSettings", () => ({ enabled: false })); +} +/** +* This is a logger singleton which either logs things or no-ops if logging is not enabled. +*/ +var debug = { + enable, + disable, + isEnabled, + log, + warn, + error +}; + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/stacktrace.js +var defaultFunctionName = ""; +/** +* Safely extract function name from itself +*/ +function getFunctionName(fn) { + try { + if (!fn || typeof fn !== "function") return defaultFunctionName; + return fn.name || defaultFunctionName; + } catch { + return defaultFunctionName; + } +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/is.js +var objectToString = Object.prototype.toString; +/** +* Checks whether given value's type is one of a few Error or Error-like +* {@link isError}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isError(wat) { + switch (objectToString.call(wat)) { + case "[object Error]": + case "[object Exception]": + case "[object DOMException]": + case "[object WebAssembly.Exception]": return true; + default: return isInstanceOf(wat, Error); + } +} +/** +* Checks whether given value is an instance of the given built-in class. +* +* @param wat The value to be checked +* @param className +* @returns A boolean representing the result. +*/ +function isBuiltin(wat, className) { + return objectToString.call(wat) === `[object ${className}]`; +} +/** +* Checks whether given value's type is a string +* {@link isString}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isString(wat) { + return isBuiltin(wat, "String"); +} +/** +* Checks whether given value's type is an object literal, or a class instance. +* {@link isPlainObject}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isPlainObject(wat) { + return isBuiltin(wat, "Object"); +} +/** +* Checks whether given value's type is an Event instance +* {@link isEvent}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isEvent(wat) { + return typeof Event !== "undefined" && isInstanceOf(wat, Event); +} +/** +* Checks whether given value's type is an Element instance +* {@link isElement}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isElement(wat) { + return typeof Element !== "undefined" && isInstanceOf(wat, Element); +} +/** +* Checks whether given value has a then function. +* @param wat A value to be checked. +*/ +function isThenable(wat) { + return Boolean(wat?.then && typeof wat.then === "function"); +} +/** +* Checks whether given value's type is a SyntheticEvent +* {@link isSyntheticEvent}. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isSyntheticEvent(wat) { + return isPlainObject(wat) && "nativeEvent" in wat && "preventDefault" in wat && "stopPropagation" in wat; +} +/** +* Checks whether given value's type is an instance of provided constructor. +* {@link isInstanceOf}. +* +* @param wat A value to be checked. +* @param base A constructor to be used in a check. +* @returns A boolean representing the result. +*/ +function isInstanceOf(wat, base) { + try { + return wat instanceof base; + } catch { + return false; + } +} +/** +* Checks whether given value's type is a Vue ViewModel. +* +* @param wat A value to be checked. +* @returns A boolean representing the result. +*/ +function isVueViewModel(wat) { + return !!(typeof wat === "object" && wat !== null && (wat.__isVue || wat._isVue)); +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/browser.js +var WINDOW = GLOBAL_OBJ; +var DEFAULT_MAX_STRING_LENGTH = 80; +/** +* Given a child DOM element, returns a query-selector statement describing that +* and its ancestors +* e.g. [HTMLElement] => body > div > input#foo.btn[name=baz] +* @returns generated DOM path +*/ +function htmlTreeAsString(elem, options = {}) { + if (!elem) return ""; + try { + let currentElem = elem; + const MAX_TRAVERSE_HEIGHT = 5; + const out = []; + let height = 0; + let len = 0; + const separator = " > "; + const sepLength = 3; + let nextStr; + const keyAttrs = Array.isArray(options) ? options : options.keyAttrs; + const maxStringLength = !Array.isArray(options) && options.maxStringLength || DEFAULT_MAX_STRING_LENGTH; + while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) { + nextStr = _htmlElementAsString(currentElem, keyAttrs); + if (nextStr === "html" || height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength) break; + out.push(nextStr); + len += nextStr.length; + currentElem = currentElem.parentNode; + } + return out.reverse().join(separator); + } catch { + return ""; + } +} +/** +* Returns a simple, query-selector representation of a DOM element +* e.g. [HTMLElement] => input#foo.btn[name=baz] +* @returns generated DOM path +*/ +function _htmlElementAsString(el, keyAttrs) { + const elem = el; + const out = []; + if (!elem?.tagName) return ""; + if (WINDOW.HTMLElement) { + if (elem instanceof HTMLElement && elem.dataset) { + if (elem.dataset["sentryComponent"]) return elem.dataset["sentryComponent"]; + if (elem.dataset["sentryElement"]) return elem.dataset["sentryElement"]; + } + } + out.push(elem.tagName.toLowerCase()); + const keyAttrPairs = keyAttrs?.length ? keyAttrs.filter((keyAttr) => elem.getAttribute(keyAttr)).map((keyAttr) => [keyAttr, elem.getAttribute(keyAttr)]) : null; + if (keyAttrPairs?.length) keyAttrPairs.forEach((keyAttrPair) => { + out.push(`[${keyAttrPair[0]}="${keyAttrPair[1]}"]`); + }); + else { + if (elem.id) out.push(`#${elem.id}`); + const className = elem.className; + if (className && isString(className)) { + const classes = className.split(/\s+/); + for (const c of classes) out.push(`.${c}`); + } + } + for (const k of [ + "aria-label", + "type", + "name", + "title", + "alt" + ]) { + const attr = elem.getAttribute(k); + if (attr) out.push(`[${k}="${attr}"]`); + } + return out.join(""); +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/object.js +/** +* Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their +* non-enumerable properties attached. +* +* @param value Initial source that we have to transform in order for it to be usable by the serializer +* @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor +* an Error. +*/ +function convertToPlainObject(value) { + if (isError(value)) return { + message: value.message, + name: value.name, + stack: value.stack, + ...getOwnProperties(value) + }; + else if (isEvent(value)) { + const newObj = { + type: value.type, + target: serializeEventTarget(value.target), + currentTarget: serializeEventTarget(value.currentTarget), + ...getOwnProperties(value) + }; + if (typeof CustomEvent !== "undefined" && isInstanceOf(value, CustomEvent)) newObj.detail = value.detail; + return newObj; + } else return value; +} +/** Creates a string representation of the target of an `Event` object */ +function serializeEventTarget(target) { + try { + return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target); + } catch { + return ""; + } +} +/** Filters out all but an object's own properties */ +function getOwnProperties(obj) { + if (typeof obj === "object" && obj !== null) { + const extractedProps = {}; + for (const property in obj) if (Object.prototype.hasOwnProperty.call(obj, property)) extractedProps[property] = obj[property]; + return extractedProps; + } else return {}; +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/normalize.js +/** +* Recursively normalizes the given object. +* +* - Creates a copy to prevent original input mutation +* - Skips non-enumerable properties +* - When stringifying, calls `toJSON` if implemented +* - Removes circular references +* - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format +* - Translates known global objects/classes to a string representations +* - Takes care of `Error` object serialization +* - Optionally limits depth of final output +* - Optionally limits number of properties/elements included in any single object/array +* +* @param input The object to be normalized. +* @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.) +* @param maxProperties The max number of elements or properties to be included in any single array or +* object in the normalized output. +* @returns A normalized version of the object, or `"**non-serializable**"` if any errors are thrown during normalization. +*/ +function normalize(input, depth = 100, maxProperties = Infinity) { + try { + return visit("", input, depth, maxProperties); + } catch (err) { + return { ERROR: `**non-serializable** (${err})` }; + } +} +/** +* Visits a node to perform normalization on it +* +* @param key The key corresponding to the given node +* @param value The node to be visited +* @param depth Optional number indicating the maximum recursion depth +* @param maxProperties Optional maximum number of properties/elements included in any single object/array +* @param memo Optional Memo class handling decycling +*/ +function visit(key, value, depth = Infinity, maxProperties = Infinity, memo = memoBuilder()) { + const [memoize, unmemoize] = memo; + if (value == null || ["boolean", "string"].includes(typeof value) || typeof value === "number" && Number.isFinite(value)) return value; + const stringified = stringifyValue(key, value); + if (!stringified.startsWith("[object ")) return stringified; + if (value["__sentry_skip_normalization__"]) return value; + const remainingDepth = typeof value["__sentry_override_normalization_depth__"] === "number" ? value["__sentry_override_normalization_depth__"] : depth; + if (remainingDepth === 0) return stringified.replace("object ", ""); + if (memoize(value)) return "[Circular ~]"; + const valueWithToJSON = value; + if (valueWithToJSON && typeof valueWithToJSON.toJSON === "function") try { + return visit("", valueWithToJSON.toJSON(), remainingDepth - 1, maxProperties, memo); + } catch {} + const normalized = Array.isArray(value) ? [] : {}; + let numAdded = 0; + const visitable = convertToPlainObject(value); + for (const visitKey in visitable) { + if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) continue; + if (numAdded >= maxProperties) { + normalized[visitKey] = "[MaxProperties ~]"; + break; + } + const visitValue = visitable[visitKey]; + normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo); + numAdded++; + } + unmemoize(value); + return normalized; +} +/** +* Stringify the given value. Handles various known special values and types. +* +* Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn +* the number 1231 into "[Object Number]", nor on `null`, as it will throw. +* +* @param value The value to stringify +* @returns A stringified representation of the given value +*/ +function stringifyValue(key, value) { + try { + if (key === "domain" && value && typeof value === "object" && value._events) return "[Domain]"; + if (key === "domainEmitter") return "[DomainEmitter]"; + if (typeof global !== "undefined" && value === global) return "[Global]"; + if (typeof window !== "undefined" && value === window) return "[Window]"; + if (typeof document !== "undefined" && value === document) return "[Document]"; + if (isVueViewModel(value)) return "[VueViewModel]"; + if (isSyntheticEvent(value)) return "[SyntheticEvent]"; + if (typeof value === "number" && !Number.isFinite(value)) return `[${value}]`; + if (typeof value === "function") return `[Function: ${getFunctionName(value)}]`; + if (typeof value === "symbol") return `[${String(value)}]`; + if (typeof value === "bigint") return `[BigInt: ${String(value)}]`; + const objName = getConstructorName(value); + if (/^HTML(\w*)Element$/.test(objName)) return `[HTMLElement: ${objName}]`; + return `[object ${objName}]`; + } catch (err) { + return `**non-serializable** (${err})`; + } +} +function getConstructorName(value) { + const prototype = Object.getPrototypeOf(value); + return prototype?.constructor ? prototype.constructor.name : "null prototype"; +} +/** +* Helper to decycle json objects +*/ +function memoBuilder() { + const inner = /* @__PURE__ */ new WeakSet(); + function memoize(obj) { + if (inner.has(obj)) return true; + inner.add(obj); + return false; + } + function unmemoize(obj) { + inner.delete(obj); + } + return [memoize, unmemoize]; +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/envelope.js +/** +* Creates an envelope. +* Make sure to always explicitly provide the generic to this function +* so that the envelope types resolve correctly. +*/ +function createEnvelope(headers, items = []) { + return [headers, items]; +} +/** +* Convenience function to loop through the items and item types of an envelope. +* (This function was mostly created because working with envelope types is painful at the moment) +* +* If the callback returns true, the rest of the items will be skipped. +*/ +function forEachEnvelopeItem(envelope, callback) { + const envelopeItems = envelope[1]; + for (const envelopeItem of envelopeItems) { + const envelopeItemType = envelopeItem[0].type; + if (callback(envelopeItem, envelopeItemType)) return true; + } + return false; +} +/** +* Encode a string to UTF8 array. +*/ +function encodeUTF8(input) { + const carrier = getSentryCarrier(GLOBAL_OBJ); + return carrier.encodePolyfill ? carrier.encodePolyfill(input) : new TextEncoder().encode(input); +} +/** +* Serializes an envelope. +*/ +function serializeEnvelope(envelope) { + const [envHeaders, items] = envelope; + let parts = JSON.stringify(envHeaders); + function append(next) { + if (typeof parts === "string") parts = typeof next === "string" ? parts + next : [encodeUTF8(parts), next]; + else parts.push(typeof next === "string" ? encodeUTF8(next) : next); + } + for (const item of items) { + const [itemHeaders, payload] = item; + append(`\n${JSON.stringify(itemHeaders)}\n`); + if (typeof payload === "string" || payload instanceof Uint8Array) append(payload); + else { + let stringifiedPayload; + try { + stringifiedPayload = JSON.stringify(payload); + } catch { + stringifiedPayload = JSON.stringify(normalize(payload)); + } + append(stringifiedPayload); + } + } + return typeof parts === "string" ? parts : concatBuffers(parts); +} +function concatBuffers(buffers) { + const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0); + const merged = new Uint8Array(totalLength); + let offset = 0; + for (const buffer of buffers) { + merged.set(buffer, offset); + offset += buffer.length; + } + return merged; +} +var ITEM_TYPE_TO_DATA_CATEGORY_MAP = { + session: "session", + sessions: "session", + attachment: "attachment", + transaction: "transaction", + event: "error", + client_report: "internal", + user_report: "default", + profile: "profile", + profile_chunk: "profile", + replay_event: "replay", + replay_recording: "replay", + check_in: "monitor", + feedback: "feedback", + span: "span", + raw_security: "security", + log: "log_item" +}; +/** +* Maps the type of an envelope item to a data category. +*/ +function envelopeItemTypeToDataCategory(type) { + return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type]; +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/syncpromise.js +/** SyncPromise internal states */ +var STATE_PENDING = 0; +var STATE_RESOLVED = 1; +var STATE_REJECTED = 2; +/** +* Creates a resolved sync promise. +* +* @param value the value to resolve the promise with +* @returns the resolved sync promise +*/ +function resolvedSyncPromise(value) { + return new SyncPromise((resolve) => { + resolve(value); + }); +} +/** +* Creates a rejected sync promise. +* +* @param value the value to reject the promise with +* @returns the rejected sync promise +*/ +function rejectedSyncPromise(reason) { + return new SyncPromise((_, reject) => { + reject(reason); + }); +} +/** +* Thenable class that behaves like a Promise and follows it's interface +* but is not async internally +*/ +var SyncPromise = class SyncPromise { + constructor(executor) { + this._state = STATE_PENDING; + this._handlers = []; + this._runExecutor(executor); + } + /** @inheritdoc */ + then(onfulfilled, onrejected) { + return new SyncPromise((resolve, reject) => { + this._handlers.push([ + false, + (result) => { + if (!onfulfilled) resolve(result); + else try { + resolve(onfulfilled(result)); + } catch (e) { + reject(e); + } + }, + (reason) => { + if (!onrejected) reject(reason); + else try { + resolve(onrejected(reason)); + } catch (e) { + reject(e); + } + } + ]); + this._executeHandlers(); + }); + } + /** @inheritdoc */ + catch(onrejected) { + return this.then((val) => val, onrejected); + } + /** @inheritdoc */ + finally(onfinally) { + return new SyncPromise((resolve, reject) => { + let val; + let isRejected; + return this.then((value) => { + isRejected = false; + val = value; + if (onfinally) onfinally(); + }, (reason) => { + isRejected = true; + val = reason; + if (onfinally) onfinally(); + }).then(() => { + if (isRejected) { + reject(val); + return; + } + resolve(val); + }); + }); + } + /** Excute the resolve/reject handlers. */ + _executeHandlers() { + if (this._state === STATE_PENDING) return; + const cachedHandlers = this._handlers.slice(); + this._handlers = []; + cachedHandlers.forEach((handler) => { + if (handler[0]) return; + if (this._state === STATE_RESOLVED) handler[1](this._value); + if (this._state === STATE_REJECTED) handler[2](this._value); + handler[0] = true; + }); + } + /** Run the executor for the SyncPromise. */ + _runExecutor(executor) { + const setResult = (state, value) => { + if (this._state !== STATE_PENDING) return; + if (isThenable(value)) { + value.then(resolve, reject); + return; + } + this._state = state; + this._value = value; + this._executeHandlers(); + }; + const resolve = (value) => { + setResult(STATE_RESOLVED, value); + }; + const reject = (reason) => { + setResult(STATE_REJECTED, reason); + }; + try { + executor(resolve, reject); + } catch (e) { + reject(e); + } + } +}; + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/promisebuffer.js +var SENTRY_BUFFER_FULL_ERROR = Symbol.for("SentryBufferFullError"); +/** +* Creates an new PromiseBuffer object with the specified limit +* @param limit max number of promises that can be stored in the buffer +*/ +function makePromiseBuffer(limit) { + const buffer = []; + function isReady() { + return limit === void 0 || buffer.length < limit; + } + /** + * Remove a promise from the queue. + * + * @param task Can be any PromiseLike + * @returns Removed promise. + */ + function remove(task) { + return buffer.splice(buffer.indexOf(task), 1)[0] || Promise.resolve(void 0); + } + /** + * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment. + * + * @param taskProducer A function producing any PromiseLike; In previous versions this used to be `task: + * PromiseLike`, but under that model, Promises were instantly created on the call-site and their executor + * functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By + * requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer + * limit check. + * @returns The original promise. + */ + function add(taskProducer) { + if (!isReady()) return rejectedSyncPromise(SENTRY_BUFFER_FULL_ERROR); + const task = taskProducer(); + if (buffer.indexOf(task) === -1) buffer.push(task); + task.then(() => remove(task)).then(null, () => remove(task).then(null, () => {})); + return task; + } + /** + * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first. + * + * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or + * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to + * `true`. + * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and + * `false` otherwise + */ + function drain(timeout) { + return new SyncPromise((resolve, reject) => { + let counter = buffer.length; + if (!counter) return resolve(true); + const capturedSetTimeout = setTimeout(() => { + if (timeout && timeout > 0) resolve(false); + }, timeout); + buffer.forEach((item) => { + resolvedSyncPromise(item).then(() => { + if (!--counter) { + clearTimeout(capturedSetTimeout); + resolve(true); + } + }, reject); + }); + }); + } + return { + $: buffer, + add, + drain + }; +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/utils/ratelimit.js +var DEFAULT_RETRY_AFTER = 60 * 1e3; +/** +* Extracts Retry-After value from the request header or returns default value +* @param header string representation of 'Retry-After' header +* @param now current unix timestamp +* +*/ +function parseRetryAfterHeader(header, now = Date.now()) { + const headerDelay = parseInt(`${header}`, 10); + if (!isNaN(headerDelay)) return headerDelay * 1e3; + const headerDate = Date.parse(`${header}`); + if (!isNaN(headerDate)) return headerDate - now; + return DEFAULT_RETRY_AFTER; +} +/** +* Gets the time that the given category is disabled until for rate limiting. +* In case no category-specific limit is set but a general rate limit across all categories is active, +* that time is returned. +* +* @return the time in ms that the category is disabled until or 0 if there's no active rate limit. +*/ +function disabledUntil(limits, dataCategory) { + return limits[dataCategory] || limits.all || 0; +} +/** +* Checks if a category is rate limited +*/ +function isRateLimited(limits, dataCategory, now = Date.now()) { + return disabledUntil(limits, dataCategory) > now; +} +/** +* Update ratelimits from incoming headers. +* +* @return the updated RateLimits object. +*/ +function updateRateLimits(limits, { statusCode, headers }, now = Date.now()) { + const updatedRateLimits = { ...limits }; + const rateLimitHeader = headers?.["x-sentry-rate-limits"]; + const retryAfterHeader = headers?.["retry-after"]; + if (rateLimitHeader) + /** + * rate limit headers are of the form + *
,
,.. + * where each
is of the form + * : : : : + * where + * is a delay in seconds + * is the event type(s) (error, transaction, etc) being rate limited and is of the form + * ;;... + * is what's being limited (org, project, or key) - ignored by SDK + * is an arbitrary string like "org_quota" - ignored by SDK + * Semicolon-separated list of metric namespace identifiers. Defines which namespace(s) will be affected. + * Only present if rate limit applies to the metric_bucket data category. + */ + for (const limit of rateLimitHeader.trim().split(",")) { + const [retryAfter, categories, , , namespaces] = limit.split(":", 5); + const headerDelay = parseInt(retryAfter, 10); + const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1e3; + if (!categories) updatedRateLimits.all = now + delay; + else for (const category of categories.split(";")) if (category === "metric_bucket") { + if (!namespaces || namespaces.split(";").includes("custom")) updatedRateLimits[category] = now + delay; + } else updatedRateLimits[category] = now + delay; + } + else if (retryAfterHeader) updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now); + else if (statusCode === 429) updatedRateLimits.all = now + 60 * 1e3; + return updatedRateLimits; +} + +//#endregion +//#region node_modules/@sentry/core/build/esm/transports/base.js +var DEFAULT_TRANSPORT_BUFFER_SIZE = 64; +/** +* Creates an instance of a Sentry `Transport` +* +* @param options +* @param makeRequest +*/ +function createTransport(options, makeRequest, buffer = makePromiseBuffer(options.bufferSize || 64)) { + let rateLimits = {}; + const flush = (timeout) => buffer.drain(timeout); + function send(envelope) { + const filteredEnvelopeItems = []; + forEachEnvelopeItem(envelope, (item, type) => { + const dataCategory = envelopeItemTypeToDataCategory(type); + if (isRateLimited(rateLimits, dataCategory)) options.recordDroppedEvent("ratelimit_backoff", dataCategory); + else filteredEnvelopeItems.push(item); + }); + if (filteredEnvelopeItems.length === 0) return resolvedSyncPromise({}); + const filteredEnvelope = createEnvelope(envelope[0], filteredEnvelopeItems); + const recordEnvelopeLoss = (reason) => { + forEachEnvelopeItem(filteredEnvelope, (item, type) => { + options.recordDroppedEvent(reason, envelopeItemTypeToDataCategory(type)); + }); + }; + const requestTask = () => makeRequest({ body: serializeEnvelope(filteredEnvelope) }).then((response) => { + if (response.statusCode !== void 0 && (response.statusCode < 200 || response.statusCode >= 300)) DEBUG_BUILD && debug.warn(`Sentry responded with status code ${response.statusCode} to sent event.`); + rateLimits = updateRateLimits(rateLimits, response); + return response; + }, (error$2) => { + recordEnvelopeLoss("network_error"); + DEBUG_BUILD && debug.error("Encountered error running transport request:", error$2); + throw error$2; + }); + return buffer.add(requestTask).then((result) => result, (error$2) => { + if (error$2 === SENTRY_BUFFER_FULL_ERROR) { + DEBUG_BUILD && debug.error("Skipped sending event because buffer is full."); + recordEnvelopeLoss("queue_overflow"); + return resolvedSyncPromise({}); + } else throw error$2; + }); + } + return { + send, + flush + }; +} + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/gaffe.ts +var creeTransportFetch = (options) => { + const creeRequete = async (requete) => { + const optionsRequete = { + body: requete.body, + headers: options.headers ?? {}, + method: "POST", + mode: "no-cors", + referrerPolicy: "no-referrer", + ...options.fetchOptions + }; + return pipe(await fetch(options.url, optionsRequete), (reponse) => ({ + headers: { + [ENTETE_GLITCHTIP_RATE_LIMITS]: reponse.headers.get(ENTETE_GLITCHTIP_RATE_LIMITS), + [ENTETE_GLITCHTIP_RETRY_AFTER]: reponse.headers.get(ENTETE_GLITCHTIP_RETRY_AFTER) + }, + statusCode: reponse.status + })); + }; + return createTransport(options, creeRequete); +}; +var client = new BrowserClient({ + dsn: "https://14362801769747a4b7c1e04eb0c7a3cc@collie.haikuatelier.com/1", + environment: "development", + integrations: [ + breadcrumbsIntegration(), + browserApiErrorsIntegration(), + captureConsoleIntegration({ levels: ["warn", "error"] }), + dedupeIntegration(), + functionToStringIntegration(), + globalHandlersIntegration(), + httpClientIntegration({ failedRequestStatusCodes: [[400, 599]] }), + httpContextIntegration(), + linkedErrorsIntegration() + ], + sendDefaultPii: true, + stackParser: defaultStackParser, + tracesSampleRate: 1, + transport: creeTransportFetch +}); +getCurrentScope().setClient(client); +client.init(); + +//#endregion +//# sourceMappingURL=gaffe.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/gaffe.js.map b/web/app/themes/haiku-atelier-2024/assets/js/gaffe.js.map new file mode 100644 index 00000000..d94e40b4 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/gaffe.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gaffe.js","names":["handlers","instrumented","addHandler","maybeInstrument","debug","triggerHandlers","getFunctionName","GLOBAL_OBJ","GLOBAL_OBJ","createEnvelope","encodeUTF8","getSentryCarrier","GLOBAL_OBJ","createEnvelope","client","debug","createEnvelope","client","_getBufferMap","getGlobalSingleton","createEnvelope","client","getGlobalSingleton","dateTimestampInSeconds","createEnvelope","error","client","debug","uuid4","isPrimitive","DEBUG_BUILD","isErrorEvent","isError","rejectedSyncPromise","isThenable","isPlainObject","log","client","name","SDK_VERSION","client","dateTimestampInSeconds","consoleSandbox","INTEGRATION_NAME","client","isInstanceOf","error","GLOBAL_OBJ","originalConsoleMethods","INTEGRATION_NAME","GLOBAL_OBJ","client","error","INTEGRATION_NAME","debug","WINDOW","GLOBAL_OBJ","debug","GLOBAL_OBJ","timestampInSeconds","isError","error","url","WINDOW","GLOBAL_OBJ","fn","isEvent","resolvedSyncPromise","isError","isPlainObject","WINDOW","DEBUG_BUILD","GLOBAL_OBJ","SDK_VERSION","getGlobalSingleton","GLOBAL_OBJ","SDK_VERSION","PREFIX","originalConsoleMethods","consoleSandbox","GLOBAL_OBJ","enable","disable","isEnabled","_getLoggerSettings","log","warn","error","_maybeLog","DEBUG_BUILD","getGlobalSingleton","debug","defaultFunctionName","getFunctionName","debug","getFunctionName","objectToString","isBuiltin","isString","fill","debug","GLOBAL_OBJ","GLOBAL_OBJ","WINDOW","GLOBAL_OBJ","WINDOW","GLOBAL_OBJ","WINDOW","handlers","WINDOW","WINDOW","isString","line","DEBUG_BUILD","INTEGRATION_NAME","client","debug","htmlTreeAsString","WINDOW","INTEGRATION_NAME","WINDOW","_wrapXHR","getFunctionName","INTEGRATION_NAME","client","error","isPrimitive","debug","isString","WINDOW","INTEGRATION_NAME","client","client","error","GLOBAL_OBJ","debug","error","optionsRequete: RequestInit"],"sources":["../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/handlers.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/globalError.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/globalUnhandledRejection.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/parseSampleRate.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/should-ignore-span.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/envelope.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/envelope.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/api.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integration.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/logs/envelope.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/logs/internal.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/metrics/envelope.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/metrics/internal.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/clientreport.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/eventUtils.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/transactionEvent.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/client.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/url.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/isSentryRequestUrl.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/ipAddress.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/sdkMetadata.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/breadcrumbs.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integrations/functiontostring.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/aggregate-errors.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/console.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/severity.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integrations/captureconsole.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/integrations/dedupe.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/breadcrumb-log-level.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/supports.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/instrument/fetch.js","../../../../../../node_modules/@sentry/browser/node_modules/@sentry/core/build/esm/utils/env.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/helpers.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/eventbuilder.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/client.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/debug-build.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/worldwide.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/version.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/carrier.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/debug-logger.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/stacktrace.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/instrument/handlers.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/is.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/object.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/misc.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/time.js","../../../../../../node_modules/@sentry-internal/browser-utils/node_modules/@sentry/core/build/esm/utils/supports.js","../../../../../../node_modules/@sentry-internal/browser-utils/build/esm/types.js","../../../../../../node_modules/@sentry-internal/browser-utils/build/esm/instrument/dom.js","../../../../../../node_modules/@sentry-internal/browser-utils/build/esm/instrument/history.js","../../../../../../node_modules/@sentry-internal/browser-utils/build/esm/instrument/xhr.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/stack-parsers.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/debug-build.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/integrations/breadcrumbs.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/integrations/browserapierrors.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/integrations/globalhandlers.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/integrations/httpcontext.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/integrations/linkederrors.js","../../../../../../node_modules/@sentry/browser/build/npm/esm/integrations/httpclient.js","../../../../../../node_modules/@sentry/core/build/esm/debug-build.js","../../../../../../node_modules/@sentry/core/build/esm/utils/worldwide.js","../../../../../../node_modules/@sentry/core/build/esm/utils/version.js","../../../../../../node_modules/@sentry/core/build/esm/carrier.js","../../../../../../node_modules/@sentry/core/build/esm/utils/debug-logger.js","../../../../../../node_modules/@sentry/core/build/esm/utils/stacktrace.js","../../../../../../node_modules/@sentry/core/build/esm/utils/is.js","../../../../../../node_modules/@sentry/core/build/esm/utils/browser.js","../../../../../../node_modules/@sentry/core/build/esm/utils/object.js","../../../../../../node_modules/@sentry/core/build/esm/utils/normalize.js","../../../../../../node_modules/@sentry/core/build/esm/utils/envelope.js","../../../../../../node_modules/@sentry/core/build/esm/utils/syncpromise.js","../../../../../../node_modules/@sentry/core/build/esm/utils/promisebuffer.js","../../../../../../node_modules/@sentry/core/build/esm/utils/ratelimit.js","../../../../../../node_modules/@sentry/core/build/esm/transports/base.js","../../src/scripts/gaffe.ts"],"sourcesContent":["import { DEBUG_BUILD } from '../debug-build.js';\nimport { debug } from '../utils/debug-logger.js';\nimport { getFunctionName } from '../utils/stacktrace.js';\n\n// We keep the handlers globally\nconst handlers = {};\nconst instrumented = {};\n\n/** Add a handler function. */\nfunction addHandler(type, handler) {\n handlers[type] = handlers[type] || [];\n handlers[type].push(handler);\n}\n\n/**\n * Reset all instrumentation handlers.\n * This can be used by tests to ensure we have a clean slate of instrumentation handlers.\n */\nfunction resetInstrumentationHandlers() {\n Object.keys(handlers).forEach(key => {\n handlers[key ] = undefined;\n });\n}\n\n/** Maybe run an instrumentation function, unless it was already called. */\nfunction maybeInstrument(type, instrumentFn) {\n if (!instrumented[type]) {\n instrumented[type] = true;\n try {\n instrumentFn();\n } catch (e) {\n DEBUG_BUILD && debug.error(`Error while instrumenting ${type}`, e);\n }\n }\n}\n\n/** Trigger handlers for a given instrumentation type. */\nfunction triggerHandlers(type, data) {\n const typeHandlers = type && handlers[type];\n if (!typeHandlers) {\n return;\n }\n\n for (const handler of typeHandlers) {\n try {\n handler(data);\n } catch (e) {\n DEBUG_BUILD &&\n debug.error(\n `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n e,\n );\n }\n }\n}\n\nexport { addHandler, maybeInstrument, resetInstrumentationHandlers, triggerHandlers };\n//# sourceMappingURL=handlers.js.map\n","import { GLOBAL_OBJ } from '../utils/worldwide.js';\nimport { addHandler, maybeInstrument, triggerHandlers } from './handlers.js';\n\nlet _oldOnErrorHandler = null;\n\n/**\n * Add an instrumentation handler for when an error is captured by the global error handler.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalErrorInstrumentationHandler(handler) {\n const type = 'error';\n addHandler(type, handler);\n maybeInstrument(type, instrumentError);\n}\n\nfunction instrumentError() {\n _oldOnErrorHandler = GLOBAL_OBJ.onerror;\n\n // Note: The reason we are doing window.onerror instead of window.addEventListener('error')\n // is that we are using this handler in the Loader Script, to handle buffered errors consistently\n GLOBAL_OBJ.onerror = function (\n msg,\n url,\n line,\n column,\n error,\n ) {\n const handlerData = {\n column,\n error,\n line,\n msg,\n url,\n };\n triggerHandlers('error', handlerData);\n\n if (_oldOnErrorHandler) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnErrorHandler.apply(this, arguments);\n }\n\n return false;\n };\n\n GLOBAL_OBJ.onerror.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexport { addGlobalErrorInstrumentationHandler };\n//# sourceMappingURL=globalError.js.map\n","import { GLOBAL_OBJ } from '../utils/worldwide.js';\nimport { addHandler, maybeInstrument, triggerHandlers } from './handlers.js';\n\nlet _oldOnUnhandledRejectionHandler = null;\n\n/**\n * Add an instrumentation handler for when an unhandled promise rejection is captured.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalUnhandledRejectionInstrumentationHandler(\n handler,\n) {\n const type = 'unhandledrejection';\n addHandler(type, handler);\n maybeInstrument(type, instrumentUnhandledRejection);\n}\n\nfunction instrumentUnhandledRejection() {\n _oldOnUnhandledRejectionHandler = GLOBAL_OBJ.onunhandledrejection;\n\n // Note: The reason we are doing window.onunhandledrejection instead of window.addEventListener('unhandledrejection')\n // is that we are using this handler in the Loader Script, to handle buffered rejections consistently\n GLOBAL_OBJ.onunhandledrejection = function (e) {\n const handlerData = e;\n triggerHandlers('unhandledrejection', handlerData);\n\n if (_oldOnUnhandledRejectionHandler) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnUnhandledRejectionHandler.apply(this, arguments);\n }\n\n return true;\n };\n\n GLOBAL_OBJ.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexport { addGlobalUnhandledRejectionInstrumentationHandler };\n//# sourceMappingURL=globalUnhandledRejection.js.map\n","/**\n * Parse a sample rate from a given value.\n * This will either return a boolean or number sample rate, if the sample rate is valid (between 0 and 1).\n * If a string is passed, we try to convert it to a number.\n *\n * Any invalid sample rate will return `undefined`.\n */\nfunction parseSampleRate(sampleRate) {\n if (typeof sampleRate === 'boolean') {\n return Number(sampleRate);\n }\n\n const rate = typeof sampleRate === 'string' ? parseFloat(sampleRate) : sampleRate;\n if (typeof rate !== 'number' || isNaN(rate) || rate < 0 || rate > 1) {\n return undefined;\n }\n\n return rate;\n}\n\nexport { parseSampleRate };\n//# sourceMappingURL=parseSampleRate.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { debug } from './debug-logger.js';\nimport { isMatchingPattern } from './string.js';\n\nfunction logIgnoredSpan(droppedSpan) {\n debug.log(`Ignoring span ${droppedSpan.op} - ${droppedSpan.description} because it matches \\`ignoreSpans\\`.`);\n}\n\n/**\n * Check if a span should be ignored based on the ignoreSpans configuration.\n */\nfunction shouldIgnoreSpan(\n span,\n ignoreSpans,\n) {\n if (!ignoreSpans?.length || !span.description) {\n return false;\n }\n\n for (const pattern of ignoreSpans) {\n if (isStringOrRegExp(pattern)) {\n if (isMatchingPattern(span.description, pattern)) {\n DEBUG_BUILD && logIgnoredSpan(span);\n return true;\n }\n continue;\n }\n\n if (!pattern.name && !pattern.op) {\n continue;\n }\n\n const nameMatches = pattern.name ? isMatchingPattern(span.description, pattern.name) : true;\n const opMatches = pattern.op ? span.op && isMatchingPattern(span.op, pattern.op) : true;\n\n // This check here is only correct because we can guarantee that we ran `isMatchingPattern`\n // for at least one of `nameMatches` and `opMatches`. So in contrary to how this looks,\n // not both op and name actually have to match. This is the most efficient way to check\n // for all combinations of name and op patterns.\n if (nameMatches && opMatches) {\n DEBUG_BUILD && logIgnoredSpan(span);\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Takes a list of spans, and a span that was dropped, and re-parents the child spans of the dropped span to the parent of the dropped span, if possible.\n * This mutates the spans array in place!\n */\nfunction reparentChildSpans(spans, dropSpan) {\n const droppedSpanParentId = dropSpan.parent_span_id;\n const droppedSpanId = dropSpan.span_id;\n\n // This should generally not happen, as we do not apply this on root spans\n // but to be safe, we just bail in this case\n if (!droppedSpanParentId) {\n return;\n }\n\n for (const span of spans) {\n if (span.parent_span_id === droppedSpanId) {\n span.parent_span_id = droppedSpanParentId;\n }\n }\n}\n\nfunction isStringOrRegExp(value) {\n return typeof value === 'string' || value instanceof RegExp;\n}\n\nexport { reparentChildSpans, shouldIgnoreSpan };\n//# sourceMappingURL=should-ignore-span.js.map\n","import { getSentryCarrier } from '../carrier.js';\nimport { dsnToString } from './dsn.js';\nimport { normalize } from './normalize.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction createEnvelope(headers, items = []) {\n return [headers, items] ;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction addItemToEnvelope(envelope, newItem) {\n const [headers, items] = envelope;\n return [headers, [...items, newItem]] ;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nfunction forEachEnvelopeItem(\n envelope,\n callback,\n) {\n const envelopeItems = envelope[1];\n\n for (const envelopeItem of envelopeItems) {\n const envelopeItemType = envelopeItem[0].type;\n const result = callback(envelopeItem, envelopeItemType);\n\n if (result) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nfunction envelopeContainsItemType(envelope, types) {\n return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8 array.\n */\nfunction encodeUTF8(input) {\n const carrier = getSentryCarrier(GLOBAL_OBJ);\n return carrier.encodePolyfill ? carrier.encodePolyfill(input) : new TextEncoder().encode(input);\n}\n\n/**\n * Decode a UTF8 array to string.\n */\nfunction decodeUTF8(input) {\n const carrier = getSentryCarrier(GLOBAL_OBJ);\n return carrier.decodePolyfill ? carrier.decodePolyfill(input) : new TextDecoder().decode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nfunction serializeEnvelope(envelope) {\n const [envHeaders, items] = envelope;\n // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n let parts = JSON.stringify(envHeaders);\n\n function append(next) {\n if (typeof parts === 'string') {\n parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts), next];\n } else {\n parts.push(typeof next === 'string' ? encodeUTF8(next) : next);\n }\n }\n\n for (const item of items) {\n const [itemHeaders, payload] = item;\n\n append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n if (typeof payload === 'string' || payload instanceof Uint8Array) {\n append(payload);\n } else {\n let stringifiedPayload;\n try {\n stringifiedPayload = JSON.stringify(payload);\n } catch {\n // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.stringify()` still\n // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n // performance impact but in this case a performance hit is better than throwing.\n stringifiedPayload = JSON.stringify(normalize(payload));\n }\n append(stringifiedPayload);\n }\n }\n\n return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers) {\n const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n const merged = new Uint8Array(totalLength);\n let offset = 0;\n for (const buffer of buffers) {\n merged.set(buffer, offset);\n offset += buffer.length;\n }\n\n return merged;\n}\n\n/**\n * Parses an envelope\n */\nfunction parseEnvelope(env) {\n let buffer = typeof env === 'string' ? encodeUTF8(env) : env;\n\n function readBinary(length) {\n const bin = buffer.subarray(0, length);\n // Replace the buffer with the remaining data excluding trailing newline\n buffer = buffer.subarray(length + 1);\n return bin;\n }\n\n function readJson() {\n let i = buffer.indexOf(0xa);\n // If we couldn't find a newline, we must have found the end of the buffer\n if (i < 0) {\n i = buffer.length;\n }\n\n return JSON.parse(decodeUTF8(readBinary(i))) ;\n }\n\n const envelopeHeader = readJson();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const items = [];\n\n while (buffer.length) {\n const itemHeader = readJson();\n const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n }\n\n return [envelopeHeader, items];\n}\n\n/**\n * Creates envelope item for a single span\n */\nfunction createSpanEnvelopeItem(spanJson) {\n const spanHeaders = {\n type: 'span',\n };\n\n return [spanHeaders, spanJson];\n}\n\n/**\n * Creates attachment envelope items\n */\nfunction createAttachmentEnvelopeItem(attachment) {\n const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data) : attachment.data;\n\n return [\n {\n type: 'attachment',\n length: buffer.length,\n filename: attachment.filename,\n content_type: attachment.contentType,\n attachment_type: attachment.attachmentType,\n },\n buffer,\n ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP = {\n session: 'session',\n sessions: 'session',\n attachment: 'attachment',\n transaction: 'transaction',\n event: 'error',\n client_report: 'internal',\n user_report: 'default',\n profile: 'profile',\n profile_chunk: 'profile',\n replay_event: 'replay',\n replay_recording: 'replay',\n check_in: 'monitor',\n feedback: 'feedback',\n span: 'span',\n raw_security: 'security',\n log: 'log_item',\n metric: 'metric',\n trace_metric: 'metric',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nfunction envelopeItemTypeToDataCategory(type) {\n return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from the metadata or an events */\nfunction getSdkMetadataForEnvelopeHeader(metadataOrEvent) {\n if (!metadataOrEvent?.sdk) {\n return;\n }\n const { name, version } = metadataOrEvent.sdk;\n return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nfunction createEventEnvelopeHeaders(\n event,\n sdkInfo,\n tunnel,\n dsn,\n) {\n const dynamicSamplingContext = event.sdkProcessingMetadata?.dynamicSamplingContext;\n return {\n event_id: event.event_id ,\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n ...(dynamicSamplingContext && {\n trace: dynamicSamplingContext,\n }),\n };\n}\n\nexport { addItemToEnvelope, createAttachmentEnvelopeItem, createEnvelope, createEventEnvelopeHeaders, createSpanEnvelopeItem, envelopeContainsItemType, envelopeItemTypeToDataCategory, forEachEnvelopeItem, getSdkMetadataForEnvelopeHeader, parseEnvelope, serializeEnvelope };\n//# sourceMappingURL=envelope.js.map\n","import { getDynamicSamplingContextFromSpan } from './tracing/dynamicSamplingContext.js';\nimport { dsnToString } from './utils/dsn.js';\nimport { getSdkMetadataForEnvelopeHeader, createEventEnvelopeHeaders, createEnvelope, createSpanEnvelopeItem } from './utils/envelope.js';\nimport { shouldIgnoreSpan } from './utils/should-ignore-span.js';\nimport { spanToJSON, showSpanDropWarning } from './utils/spanUtils.js';\n\n/**\n * Apply SdkInfo (name, version, packages, integrations) to the corresponding event key.\n * Merge with existing data if any.\n *\n * @internal, exported only for testing\n **/\nfunction _enhanceEventWithSdkInfo(event, newSdkInfo) {\n if (!newSdkInfo) {\n return event;\n }\n\n const eventSdkInfo = event.sdk || {};\n\n event.sdk = {\n ...eventSdkInfo,\n name: eventSdkInfo.name || newSdkInfo.name,\n version: eventSdkInfo.version || newSdkInfo.version,\n integrations: [...(event.sdk?.integrations || []), ...(newSdkInfo.integrations || [])],\n packages: [...(event.sdk?.packages || []), ...(newSdkInfo.packages || [])],\n settings:\n event.sdk?.settings || newSdkInfo.settings\n ? {\n ...event.sdk?.settings,\n ...newSdkInfo.settings,\n }\n : undefined,\n };\n\n return event;\n}\n\n/** Creates an envelope from a Session */\nfunction createSessionEnvelope(\n session,\n dsn,\n metadata,\n tunnel,\n) {\n const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata);\n const envelopeHeaders = {\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n };\n\n const envelopeItem =\n 'aggregates' in session ? [{ type: 'sessions' }, session] : [{ type: 'session' }, session.toJSON()];\n\n return createEnvelope(envelopeHeaders, [envelopeItem]);\n}\n\n/**\n * Create an Envelope from an event.\n */\nfunction createEventEnvelope(\n event,\n dsn,\n metadata,\n tunnel,\n) {\n const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata);\n\n /*\n Note: Due to TS, event.type may be `replay_event`, theoretically.\n In practice, we never call `createEventEnvelope` with `replay_event` type,\n and we'd have to adjust a looot of types to make this work properly.\n We want to avoid casting this around, as that could lead to bugs (e.g. when we add another type)\n So the safe choice is to really guard against the replay_event type here.\n */\n const eventType = event.type && event.type !== 'replay_event' ? event.type : 'event';\n\n _enhanceEventWithSdkInfo(event, metadata?.sdk);\n\n const envelopeHeaders = createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn);\n\n // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n delete event.sdkProcessingMetadata;\n\n const eventItem = [{ type: eventType }, event];\n return createEnvelope(envelopeHeaders, [eventItem]);\n}\n\n/**\n * Create envelope from Span item.\n *\n * Takes an optional client and runs spans through `beforeSendSpan` if available.\n */\nfunction createSpanEnvelope(spans, client) {\n function dscHasRequiredProps(dsc) {\n return !!dsc.trace_id && !!dsc.public_key;\n }\n\n // For the moment we'll obtain the DSC from the first span in the array\n // This might need to be changed if we permit sending multiple spans from\n // different segments in one envelope\n const dsc = getDynamicSamplingContextFromSpan(spans[0]);\n\n const dsn = client?.getDsn();\n const tunnel = client?.getOptions().tunnel;\n\n const headers = {\n sent_at: new Date().toISOString(),\n ...(dscHasRequiredProps(dsc) && { trace: dsc }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n };\n\n const { beforeSendSpan, ignoreSpans } = client?.getOptions() || {};\n\n const filteredSpans = ignoreSpans?.length\n ? spans.filter(span => !shouldIgnoreSpan(spanToJSON(span), ignoreSpans))\n : spans;\n const droppedSpans = spans.length - filteredSpans.length;\n\n if (droppedSpans) {\n client?.recordDroppedEvent('before_send', 'span', droppedSpans);\n }\n\n const convertToSpanJSON = beforeSendSpan\n ? (span) => {\n const spanJson = spanToJSON(span);\n const processedSpan = beforeSendSpan(spanJson);\n\n if (!processedSpan) {\n showSpanDropWarning();\n return spanJson;\n }\n\n return processedSpan;\n }\n : spanToJSON;\n\n const items = [];\n for (const span of filteredSpans) {\n const spanJson = convertToSpanJSON(span);\n if (spanJson) {\n items.push(createSpanEnvelopeItem(spanJson));\n }\n }\n\n return createEnvelope(headers, items);\n}\n\nexport { _enhanceEventWithSdkInfo, createEventEnvelope, createSessionEnvelope, createSpanEnvelope };\n//# sourceMappingURL=envelope.js.map\n","import { makeDsn, dsnToString } from './utils/dsn.js';\n\nconst SENTRY_API_VERSION = '7';\n\n/** Returns the prefix to construct Sentry ingestion API endpoints. */\nfunction getBaseApiEndpoint(dsn) {\n const protocol = dsn.protocol ? `${dsn.protocol}:` : '';\n const port = dsn.port ? `:${dsn.port}` : '';\n return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ''}/api/`;\n}\n\n/** Returns the ingest API endpoint for target. */\nfunction _getIngestEndpoint(dsn) {\n return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`;\n}\n\n/** Returns a URL-encoded string with auth config suitable for a query string. */\nfunction _encodedAuth(dsn, sdkInfo) {\n const params = {\n sentry_version: SENTRY_API_VERSION,\n };\n\n if (dsn.publicKey) {\n // We send only the minimum set of required information. See\n // https://github.com/getsentry/sentry-javascript/issues/2572.\n params.sentry_key = dsn.publicKey;\n }\n\n if (sdkInfo) {\n params.sentry_client = `${sdkInfo.name}/${sdkInfo.version}`;\n }\n\n return new URLSearchParams(params).toString();\n}\n\n/**\n * Returns the envelope endpoint URL with auth in the query string.\n *\n * Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests.\n */\nfunction getEnvelopeEndpointWithUrlEncodedAuth(dsn, tunnel, sdkInfo) {\n return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`;\n}\n\n/** Returns the url to the report dialog endpoint. */\nfunction getReportDialogEndpoint(dsnLike, dialogOptions) {\n const dsn = makeDsn(dsnLike);\n if (!dsn) {\n return '';\n }\n\n const endpoint = `${getBaseApiEndpoint(dsn)}embed/error-page/`;\n\n let encodedOptions = `dsn=${dsnToString(dsn)}`;\n for (const key in dialogOptions) {\n if (key === 'dsn') {\n continue;\n }\n\n if (key === 'onClose') {\n continue;\n }\n\n if (key === 'user') {\n const user = dialogOptions.user;\n if (!user) {\n continue;\n }\n if (user.name) {\n encodedOptions += `&name=${encodeURIComponent(user.name)}`;\n }\n if (user.email) {\n encodedOptions += `&email=${encodeURIComponent(user.email)}`;\n }\n } else {\n encodedOptions += `&${encodeURIComponent(key)}=${encodeURIComponent(dialogOptions[key] )}`;\n }\n }\n\n return `${endpoint}?${encodedOptions}`;\n}\n\nexport { getEnvelopeEndpointWithUrlEncodedAuth, getReportDialogEndpoint };\n//# sourceMappingURL=api.js.map\n","import { getClient } from './currentScopes.js';\nimport { DEBUG_BUILD } from './debug-build.js';\nimport { debug } from './utils/debug-logger.js';\n\nconst installedIntegrations = [];\n\n/** Map of integrations assigned to a client */\n\n/**\n * Remove duplicates from the given array, preferring the last instance of any duplicate. Not guaranteed to\n * preserve the order of integrations in the array.\n *\n * @private\n */\nfunction filterDuplicates(integrations) {\n const integrationsByName = {};\n\n integrations.forEach((currentInstance) => {\n const { name } = currentInstance;\n\n const existingInstance = integrationsByName[name];\n\n // We want integrations later in the array to overwrite earlier ones of the same type, except that we never want a\n // default instance to overwrite an existing user instance\n if (existingInstance && !existingInstance.isDefaultInstance && currentInstance.isDefaultInstance) {\n return;\n }\n\n integrationsByName[name] = currentInstance;\n });\n\n return Object.values(integrationsByName);\n}\n\n/** Gets integrations to install */\nfunction getIntegrationsToSetup(\n options,\n) {\n const defaultIntegrations = options.defaultIntegrations || [];\n const userIntegrations = options.integrations;\n\n // We flag default instances, so that later we can tell them apart from any user-created instances of the same class\n defaultIntegrations.forEach((integration) => {\n integration.isDefaultInstance = true;\n });\n\n let integrations;\n\n if (Array.isArray(userIntegrations)) {\n integrations = [...defaultIntegrations, ...userIntegrations];\n } else if (typeof userIntegrations === 'function') {\n const resolvedUserIntegrations = userIntegrations(defaultIntegrations);\n integrations = Array.isArray(resolvedUserIntegrations) ? resolvedUserIntegrations : [resolvedUserIntegrations];\n } else {\n integrations = defaultIntegrations;\n }\n\n return filterDuplicates(integrations);\n}\n\n/**\n * Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default\n * integrations are added unless they were already provided before.\n * @param integrations array of integration instances\n * @param withDefault should enable default integrations\n */\nfunction setupIntegrations(client, integrations) {\n const integrationIndex = {};\n\n integrations.forEach((integration) => {\n // guard against empty provided integrations\n if (integration) {\n setupIntegration(client, integration, integrationIndex);\n }\n });\n\n return integrationIndex;\n}\n\n/**\n * Execute the `afterAllSetup` hooks of the given integrations.\n */\nfunction afterSetupIntegrations(client, integrations) {\n for (const integration of integrations) {\n // guard against empty provided integrations\n if (integration?.afterAllSetup) {\n integration.afterAllSetup(client);\n }\n }\n}\n\n/** Setup a single integration. */\nfunction setupIntegration(client, integration, integrationIndex) {\n if (integrationIndex[integration.name]) {\n DEBUG_BUILD && debug.log(`Integration skipped because it was already installed: ${integration.name}`);\n return;\n }\n integrationIndex[integration.name] = integration;\n\n // `setupOnce` is only called the first time\n if (installedIntegrations.indexOf(integration.name) === -1 && typeof integration.setupOnce === 'function') {\n integration.setupOnce();\n installedIntegrations.push(integration.name);\n }\n\n // `setup` is run for each client\n if (integration.setup && typeof integration.setup === 'function') {\n integration.setup(client);\n }\n\n if (typeof integration.preprocessEvent === 'function') {\n const callback = integration.preprocessEvent.bind(integration) ;\n client.on('preprocessEvent', (event, hint) => callback(event, hint, client));\n }\n\n if (typeof integration.processEvent === 'function') {\n const callback = integration.processEvent.bind(integration) ;\n\n const processor = Object.assign((event, hint) => callback(event, hint, client), {\n id: integration.name,\n });\n\n client.addEventProcessor(processor);\n }\n\n DEBUG_BUILD && debug.log(`Integration installed: ${integration.name}`);\n}\n\n/** Add an integration to the current scope's client. */\nfunction addIntegration(integration) {\n const client = getClient();\n\n if (!client) {\n DEBUG_BUILD && debug.warn(`Cannot add integration \"${integration.name}\" because no SDK Client is available.`);\n return;\n }\n\n client.addIntegration(integration);\n}\n\n/**\n * Define an integration function that can be used to create an integration instance.\n * Note that this by design hides the implementation details of the integration, as they are considered internal.\n */\nfunction defineIntegration(fn) {\n return fn;\n}\n\nexport { addIntegration, afterSetupIntegrations, defineIntegration, getIntegrationsToSetup, installedIntegrations, setupIntegration, setupIntegrations };\n//# sourceMappingURL=integration.js.map\n","import { dsnToString } from '../utils/dsn.js';\nimport { createEnvelope } from '../utils/envelope.js';\n\n/**\n * Creates a log container envelope item for a list of logs.\n *\n * @param items - The logs to include in the envelope.\n * @returns The created log container envelope item.\n */\nfunction createLogContainerEnvelopeItem(items) {\n return [\n {\n type: 'log',\n item_count: items.length,\n content_type: 'application/vnd.sentry.items.log+json',\n },\n {\n items,\n },\n ];\n}\n\n/**\n * Creates an envelope for a list of logs.\n *\n * Logs from multiple traces can be included in the same envelope.\n *\n * @param logs - The logs to include in the envelope.\n * @param metadata - The metadata to include in the envelope.\n * @param tunnel - The tunnel to include in the envelope.\n * @param dsn - The DSN to include in the envelope.\n * @returns The created envelope.\n */\nfunction createLogEnvelope(\n logs,\n metadata,\n tunnel,\n dsn,\n) {\n const headers = {};\n\n if (metadata?.sdk) {\n headers.sdk = {\n name: metadata.sdk.name,\n version: metadata.sdk.version,\n };\n }\n\n if (!!tunnel && !!dsn) {\n headers.dsn = dsnToString(dsn);\n }\n\n return createEnvelope(headers, [createLogContainerEnvelopeItem(logs)]);\n}\n\nexport { createLogContainerEnvelopeItem, createLogEnvelope };\n//# sourceMappingURL=envelope.js.map\n","import { getGlobalSingleton } from '../carrier.js';\nimport { getCurrentScope, getClient, getGlobalScope, getIsolationScope } from '../currentScopes.js';\nimport { DEBUG_BUILD } from '../debug-build.js';\nimport { mergeScopeData } from '../utils/applyScopeDataToEvent.js';\nimport { debug, consoleSandbox } from '../utils/debug-logger.js';\nimport { isParameterizedString } from '../utils/is.js';\nimport { _getSpanForScope } from '../utils/spanOnScope.js';\nimport { timestampInSeconds } from '../utils/time.js';\nimport { _getTraceInfoFromScope } from '../utils/trace-info.js';\nimport { SEVERITY_TEXT_TO_SEVERITY_NUMBER } from './constants.js';\nimport { createLogEnvelope } from './envelope.js';\n\nconst MAX_LOG_BUFFER_SIZE = 100;\n\n/**\n * Converts a log attribute to a serialized log attribute.\n *\n * @param key - The key of the log attribute.\n * @param value - The value of the log attribute.\n * @returns The serialized log attribute.\n */\nfunction logAttributeToSerializedLogAttribute(value) {\n switch (typeof value) {\n case 'number':\n if (Number.isInteger(value)) {\n return {\n value,\n type: 'integer',\n };\n }\n return {\n value,\n type: 'double',\n };\n case 'boolean':\n return {\n value,\n type: 'boolean',\n };\n case 'string':\n return {\n value,\n type: 'string',\n };\n default: {\n let stringValue = '';\n try {\n stringValue = JSON.stringify(value) ?? '';\n } catch {\n // Do nothing\n }\n return {\n value: stringValue,\n type: 'string',\n };\n }\n }\n}\n\n/**\n * Sets a log attribute if the value exists and the attribute key is not already present.\n *\n * @param logAttributes - The log attributes object to modify.\n * @param key - The attribute key to set.\n * @param value - The value to set (only sets if truthy and key not present).\n * @param setEvenIfPresent - Whether to set the attribute if it is present. Defaults to true.\n */\nfunction setLogAttribute(\n logAttributes,\n key,\n value,\n setEvenIfPresent = true,\n) {\n if (value && (!logAttributes[key] || setEvenIfPresent)) {\n logAttributes[key] = value;\n }\n}\n\n/**\n * Captures a serialized log event and adds it to the log buffer for the given client.\n *\n * @param client - A client. Uses the current client if not provided.\n * @param serializedLog - The serialized log event to capture.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureSerializedLog(client, serializedLog) {\n const bufferMap = _getBufferMap();\n\n const logBuffer = _INTERNAL_getLogBuffer(client);\n if (logBuffer === undefined) {\n bufferMap.set(client, [serializedLog]);\n } else {\n bufferMap.set(client, [...logBuffer, serializedLog]);\n if (logBuffer.length >= MAX_LOG_BUFFER_SIZE) {\n _INTERNAL_flushLogsBuffer(client, logBuffer);\n }\n }\n}\n\n/**\n * Captures a log event and sends it to Sentry.\n *\n * @param log - The log event to capture.\n * @param scope - A scope. Uses the current scope if not provided.\n * @param client - A client. Uses the current client if not provided.\n * @param captureSerializedLog - A function to capture the serialized log.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureLog(\n beforeLog,\n currentScope = getCurrentScope(),\n captureSerializedLog = _INTERNAL_captureSerializedLog,\n) {\n const client = currentScope?.getClient() ?? getClient();\n if (!client) {\n DEBUG_BUILD && debug.warn('No client available to capture log.');\n return;\n }\n\n const { release, environment, enableLogs = false, beforeSendLog } = client.getOptions();\n if (!enableLogs) {\n DEBUG_BUILD && debug.warn('logging option not enabled, log will not be captured.');\n return;\n }\n\n const [, traceContext] = _getTraceInfoFromScope(client, currentScope);\n\n const processedLogAttributes = {\n ...beforeLog.attributes,\n };\n\n const {\n user: { id, email, username },\n } = getMergedScopeData(currentScope);\n setLogAttribute(processedLogAttributes, 'user.id', id, false);\n setLogAttribute(processedLogAttributes, 'user.email', email, false);\n setLogAttribute(processedLogAttributes, 'user.name', username, false);\n\n setLogAttribute(processedLogAttributes, 'sentry.release', release);\n setLogAttribute(processedLogAttributes, 'sentry.environment', environment);\n\n const { name, version } = client.getSdkMetadata()?.sdk ?? {};\n setLogAttribute(processedLogAttributes, 'sentry.sdk.name', name);\n setLogAttribute(processedLogAttributes, 'sentry.sdk.version', version);\n\n const replay = client.getIntegrationByName\n\n('Replay');\n\n const replayId = replay?.getReplayId(true);\n setLogAttribute(processedLogAttributes, 'sentry.replay_id', replayId);\n\n if (replayId && replay?.getRecordingMode() === 'buffer') {\n // We send this so we can identify cases where the replayId is attached but the replay itself might not have been sent to Sentry\n setLogAttribute(processedLogAttributes, 'sentry._internal.replay_is_buffering', true);\n }\n\n const beforeLogMessage = beforeLog.message;\n if (isParameterizedString(beforeLogMessage)) {\n const { __sentry_template_string__, __sentry_template_values__ = [] } = beforeLogMessage;\n if (__sentry_template_values__?.length) {\n processedLogAttributes['sentry.message.template'] = __sentry_template_string__;\n }\n __sentry_template_values__.forEach((param, index) => {\n processedLogAttributes[`sentry.message.parameter.${index}`] = param;\n });\n }\n\n const span = _getSpanForScope(currentScope);\n // Add the parent span ID to the log attributes for trace context\n setLogAttribute(processedLogAttributes, 'sentry.trace.parent_span_id', span?.spanContext().spanId);\n\n const processedLog = { ...beforeLog, attributes: processedLogAttributes };\n\n client.emit('beforeCaptureLog', processedLog);\n\n // We need to wrap this in `consoleSandbox` to avoid recursive calls to `beforeSendLog`\n const log = beforeSendLog ? consoleSandbox(() => beforeSendLog(processedLog)) : processedLog;\n if (!log) {\n client.recordDroppedEvent('before_send', 'log_item', 1);\n DEBUG_BUILD && debug.warn('beforeSendLog returned null, log will not be captured.');\n return;\n }\n\n const { level, message, attributes = {}, severityNumber } = log;\n\n const serializedLog = {\n timestamp: timestampInSeconds(),\n level,\n body: message,\n trace_id: traceContext?.trace_id,\n severity_number: severityNumber ?? SEVERITY_TEXT_TO_SEVERITY_NUMBER[level],\n attributes: Object.keys(attributes).reduce(\n (acc, key) => {\n acc[key] = logAttributeToSerializedLogAttribute(attributes[key]);\n return acc;\n },\n {} ,\n ),\n };\n\n captureSerializedLog(client, serializedLog);\n\n client.emit('afterCaptureLog', log);\n}\n\n/**\n * Flushes the logs buffer to Sentry.\n *\n * @param client - A client.\n * @param maybeLogBuffer - A log buffer. Uses the log buffer for the given client if not provided.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_flushLogsBuffer(client, maybeLogBuffer) {\n const logBuffer = maybeLogBuffer ?? _INTERNAL_getLogBuffer(client) ?? [];\n if (logBuffer.length === 0) {\n return;\n }\n\n const clientOptions = client.getOptions();\n const envelope = createLogEnvelope(logBuffer, clientOptions._metadata, clientOptions.tunnel, client.getDsn());\n\n // Clear the log buffer after envelopes have been constructed.\n _getBufferMap().set(client, []);\n\n client.emit('flushLogs');\n\n // sendEnvelope should not throw\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n client.sendEnvelope(envelope);\n}\n\n/**\n * Returns the log buffer for a given client.\n *\n * Exported for testing purposes.\n *\n * @param client - The client to get the log buffer for.\n * @returns The log buffer for the given client.\n */\nfunction _INTERNAL_getLogBuffer(client) {\n return _getBufferMap().get(client);\n}\n\n/**\n * Get the scope data for the current scope after merging with the\n * global scope and isolation scope.\n *\n * @param currentScope - The current scope.\n * @returns The scope data.\n */\nfunction getMergedScopeData(currentScope) {\n const scopeData = getGlobalScope().getScopeData();\n mergeScopeData(scopeData, getIsolationScope().getScopeData());\n mergeScopeData(scopeData, currentScope.getScopeData());\n return scopeData;\n}\n\nfunction _getBufferMap() {\n // The reference to the Client <> LogBuffer map is stored on the carrier to ensure it's always the same\n return getGlobalSingleton('clientToLogBufferMap', () => new WeakMap());\n}\n\nexport { _INTERNAL_captureLog, _INTERNAL_captureSerializedLog, _INTERNAL_flushLogsBuffer, _INTERNAL_getLogBuffer, logAttributeToSerializedLogAttribute };\n//# sourceMappingURL=internal.js.map\n","import { dsnToString } from '../utils/dsn.js';\nimport { createEnvelope } from '../utils/envelope.js';\n\n/**\n * Creates a metric container envelope item for a list of metrics.\n *\n * @param items - The metrics to include in the envelope.\n * @returns The created metric container envelope item.\n */\nfunction createMetricContainerEnvelopeItem(items) {\n return [\n {\n type: 'trace_metric',\n item_count: items.length,\n content_type: 'application/vnd.sentry.items.trace-metric+json',\n } ,\n {\n items,\n },\n ];\n}\n\n/**\n * Creates an envelope for a list of metrics.\n *\n * Metrics from multiple traces can be included in the same envelope.\n *\n * @param metrics - The metrics to include in the envelope.\n * @param metadata - The metadata to include in the envelope.\n * @param tunnel - The tunnel to include in the envelope.\n * @param dsn - The DSN to include in the envelope.\n * @returns The created envelope.\n */\nfunction createMetricEnvelope(\n metrics,\n metadata,\n tunnel,\n dsn,\n) {\n const headers = {};\n\n if (metadata?.sdk) {\n headers.sdk = {\n name: metadata.sdk.name,\n version: metadata.sdk.version,\n };\n }\n\n if (!!tunnel && !!dsn) {\n headers.dsn = dsnToString(dsn);\n }\n\n return createEnvelope(headers, [createMetricContainerEnvelopeItem(metrics)]);\n}\n\nexport { createMetricContainerEnvelopeItem, createMetricEnvelope };\n//# sourceMappingURL=envelope.js.map\n","import { getGlobalSingleton } from '../carrier.js';\nimport { getCurrentScope, getClient, getGlobalScope, getIsolationScope } from '../currentScopes.js';\nimport { DEBUG_BUILD } from '../debug-build.js';\nimport { mergeScopeData } from '../utils/applyScopeDataToEvent.js';\nimport { debug } from '../utils/debug-logger.js';\nimport { _getSpanForScope } from '../utils/spanOnScope.js';\nimport { timestampInSeconds } from '../utils/time.js';\nimport { _getTraceInfoFromScope } from '../utils/trace-info.js';\nimport { createMetricEnvelope } from './envelope.js';\n\nconst MAX_METRIC_BUFFER_SIZE = 100;\n\n/**\n * Converts a metric attribute to a serialized metric attribute.\n *\n * @param value - The value of the metric attribute.\n * @returns The serialized metric attribute.\n */\nfunction metricAttributeToSerializedMetricAttribute(value) {\n switch (typeof value) {\n case 'number':\n if (Number.isInteger(value)) {\n return {\n value,\n type: 'integer',\n };\n }\n return {\n value,\n type: 'double',\n };\n case 'boolean':\n return {\n value,\n type: 'boolean',\n };\n case 'string':\n return {\n value,\n type: 'string',\n };\n default: {\n let stringValue = '';\n try {\n stringValue = JSON.stringify(value) ?? '';\n } catch {\n // Do nothing\n }\n return {\n value: stringValue,\n type: 'string',\n };\n }\n }\n}\n\n/**\n * Sets a metric attribute if the value exists and the attribute key is not already present.\n *\n * @param metricAttributes - The metric attributes object to modify.\n * @param key - The attribute key to set.\n * @param value - The value to set (only sets if truthy and key not present).\n * @param setEvenIfPresent - Whether to set the attribute if it is present. Defaults to true.\n */\nfunction setMetricAttribute(\n metricAttributes,\n key,\n value,\n setEvenIfPresent = true,\n) {\n if (value && (setEvenIfPresent || !(key in metricAttributes))) {\n metricAttributes[key] = value;\n }\n}\n\n/**\n * Captures a serialized metric event and adds it to the metric buffer for the given client.\n *\n * @param client - A client. Uses the current client if not provided.\n * @param serializedMetric - The serialized metric event to capture.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureSerializedMetric(client, serializedMetric) {\n const bufferMap = _getBufferMap();\n\n const metricBuffer = _INTERNAL_getMetricBuffer(client);\n if (metricBuffer === undefined) {\n bufferMap.set(client, [serializedMetric]);\n } else {\n bufferMap.set(client, [...metricBuffer, serializedMetric]);\n if (metricBuffer.length >= MAX_METRIC_BUFFER_SIZE) {\n _INTERNAL_flushMetricsBuffer(client, metricBuffer);\n }\n }\n}\n\n/**\n * Options for capturing a metric internally.\n */\n\n/**\n * Captures a metric event and sends it to Sentry.\n *\n * @param metric - The metric event to capture.\n * @param options - Options for capturing the metric.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureMetric(beforeMetric, options) {\n const currentScope = options?.scope ?? getCurrentScope();\n const captureSerializedMetric = options?.captureSerializedMetric ?? _INTERNAL_captureSerializedMetric;\n const client = currentScope?.getClient() ?? getClient();\n if (!client) {\n DEBUG_BUILD && debug.warn('No client available to capture metric.');\n return;\n }\n\n const { release, environment, _experiments } = client.getOptions();\n if (!_experiments?.enableMetrics) {\n DEBUG_BUILD && debug.warn('metrics option not enabled, metric will not be captured.');\n return;\n }\n\n const [, traceContext] = _getTraceInfoFromScope(client, currentScope);\n\n const processedMetricAttributes = {\n ...beforeMetric.attributes,\n };\n\n const {\n user: { id, email, username },\n } = getMergedScopeData(currentScope);\n setMetricAttribute(processedMetricAttributes, 'user.id', id, false);\n setMetricAttribute(processedMetricAttributes, 'user.email', email, false);\n setMetricAttribute(processedMetricAttributes, 'user.name', username, false);\n\n setMetricAttribute(processedMetricAttributes, 'sentry.release', release);\n setMetricAttribute(processedMetricAttributes, 'sentry.environment', environment);\n\n const { name, version } = client.getSdkMetadata()?.sdk ?? {};\n setMetricAttribute(processedMetricAttributes, 'sentry.sdk.name', name);\n setMetricAttribute(processedMetricAttributes, 'sentry.sdk.version', version);\n\n const replay = client.getIntegrationByName\n\n('Replay');\n\n const replayId = replay?.getReplayId(true);\n\n setMetricAttribute(processedMetricAttributes, 'sentry.replay_id', replayId);\n\n if (replayId && replay?.getRecordingMode() === 'buffer') {\n // We send this so we can identify cases where the replayId is attached but the replay itself might not have been sent to Sentry\n setMetricAttribute(processedMetricAttributes, 'sentry._internal.replay_is_buffering', true);\n }\n\n const metric = {\n ...beforeMetric,\n attributes: processedMetricAttributes,\n };\n\n // Run beforeSendMetric callback\n const processedMetric = _experiments?.beforeSendMetric ? _experiments.beforeSendMetric(metric) : metric;\n\n if (!processedMetric) {\n DEBUG_BUILD && debug.log('`beforeSendMetric` returned `null`, will not send metric.');\n return;\n }\n\n const serializedAttributes = {};\n for (const key in processedMetric.attributes) {\n if (processedMetric.attributes[key] !== undefined) {\n serializedAttributes[key] = metricAttributeToSerializedMetricAttribute(processedMetric.attributes[key]);\n }\n }\n\n const span = _getSpanForScope(currentScope);\n const traceId = span ? span.spanContext().traceId : traceContext?.trace_id;\n const spanId = span ? span.spanContext().spanId : undefined;\n\n const serializedMetric = {\n timestamp: timestampInSeconds(),\n trace_id: traceId,\n span_id: spanId,\n name: processedMetric.name,\n type: processedMetric.type,\n unit: processedMetric.unit,\n value: processedMetric.value,\n attributes: serializedAttributes,\n };\n\n DEBUG_BUILD && debug.log('[Metric]', serializedMetric);\n\n captureSerializedMetric(client, serializedMetric);\n\n client.emit('afterCaptureMetric', metric);\n}\n\n/**\n * Flushes the metrics buffer to Sentry.\n *\n * @param client - A client.\n * @param maybeMetricBuffer - A metric buffer. Uses the metric buffer for the given client if not provided.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_flushMetricsBuffer(client, maybeMetricBuffer) {\n const metricBuffer = maybeMetricBuffer ?? _INTERNAL_getMetricBuffer(client) ?? [];\n if (metricBuffer.length === 0) {\n return;\n }\n\n const clientOptions = client.getOptions();\n const envelope = createMetricEnvelope(metricBuffer, clientOptions._metadata, clientOptions.tunnel, client.getDsn());\n\n // Clear the metric buffer after envelopes have been constructed.\n _getBufferMap().set(client, []);\n\n client.emit('flushMetrics');\n\n // sendEnvelope should not throw\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n client.sendEnvelope(envelope);\n}\n\n/**\n * Returns the metric buffer for a given client.\n *\n * Exported for testing purposes.\n *\n * @param client - The client to get the metric buffer for.\n * @returns The metric buffer for the given client.\n */\nfunction _INTERNAL_getMetricBuffer(client) {\n return _getBufferMap().get(client);\n}\n\n/**\n * Get the scope data for the current scope after merging with the\n * global scope and isolation scope.\n *\n * @param currentScope - The current scope.\n * @returns The scope data.\n */\nfunction getMergedScopeData(currentScope) {\n const scopeData = getGlobalScope().getScopeData();\n mergeScopeData(scopeData, getIsolationScope().getScopeData());\n mergeScopeData(scopeData, currentScope.getScopeData());\n return scopeData;\n}\n\nfunction _getBufferMap() {\n // The reference to the Client <> MetricBuffer map is stored on the carrier to ensure it's always the same\n return getGlobalSingleton('clientToMetricBufferMap', () => new WeakMap());\n}\n\nexport { _INTERNAL_captureMetric, _INTERNAL_captureSerializedMetric, _INTERNAL_flushMetricsBuffer, _INTERNAL_getMetricBuffer, metricAttributeToSerializedMetricAttribute };\n//# sourceMappingURL=internal.js.map\n","import { createEnvelope } from './envelope.js';\nimport { dateTimestampInSeconds } from './time.js';\n\n/**\n * Creates client report envelope\n * @param discarded_events An array of discard events\n * @param dsn A DSN that can be set on the header. Optional.\n */\nfunction createClientReportEnvelope(\n discarded_events,\n dsn,\n timestamp,\n) {\n const clientReportItem = [\n { type: 'client_report' },\n {\n timestamp: timestamp || dateTimestampInSeconds(),\n discarded_events,\n },\n ];\n return createEnvelope(dsn ? { dsn } : {}, [clientReportItem]);\n}\n\nexport { createClientReportEnvelope };\n//# sourceMappingURL=clientreport.js.map\n","/**\n * Get a list of possible event messages from a Sentry event.\n */\nfunction getPossibleEventMessages(event) {\n const possibleMessages = [];\n\n if (event.message) {\n possibleMessages.push(event.message);\n }\n\n try {\n // @ts-expect-error Try catching to save bundle size\n const lastException = event.exception.values[event.exception.values.length - 1];\n if (lastException?.value) {\n possibleMessages.push(lastException.value);\n if (lastException.type) {\n possibleMessages.push(`${lastException.type}: ${lastException.value}`);\n }\n }\n } catch {\n // ignore errors here\n }\n\n return possibleMessages;\n}\n\nexport { getPossibleEventMessages };\n//# sourceMappingURL=eventUtils.js.map\n","import { SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME, SEMANTIC_ATTRIBUTE_PROFILE_ID } from '../semanticAttributes.js';\n\n/**\n * Converts a transaction event to a span JSON object.\n */\nfunction convertTransactionEventToSpanJson(event) {\n const { trace_id, parent_span_id, span_id, status, origin, data, op } = event.contexts?.trace ?? {};\n\n return {\n data: data ?? {},\n description: event.transaction,\n op,\n parent_span_id,\n span_id: span_id ?? '',\n start_timestamp: event.start_timestamp ?? 0,\n status,\n timestamp: event.timestamp,\n trace_id: trace_id ?? '',\n origin,\n profile_id: data?.[SEMANTIC_ATTRIBUTE_PROFILE_ID] ,\n exclusive_time: data?.[SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME] ,\n measurements: event.measurements,\n is_segment: true,\n };\n}\n\n/**\n * Converts a span JSON object to a transaction event.\n */\nfunction convertSpanJsonToTransactionEvent(span) {\n return {\n type: 'transaction',\n timestamp: span.timestamp,\n start_timestamp: span.start_timestamp,\n transaction: span.description,\n contexts: {\n trace: {\n trace_id: span.trace_id,\n span_id: span.span_id,\n parent_span_id: span.parent_span_id,\n op: span.op,\n status: span.status,\n origin: span.origin,\n data: {\n ...span.data,\n ...(span.profile_id && { [SEMANTIC_ATTRIBUTE_PROFILE_ID]: span.profile_id }),\n ...(span.exclusive_time && { [SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME]: span.exclusive_time }),\n },\n },\n },\n measurements: span.measurements,\n };\n}\n\nexport { convertSpanJsonToTransactionEvent, convertTransactionEventToSpanJson };\n//# sourceMappingURL=transactionEvent.js.map\n","import { getEnvelopeEndpointWithUrlEncodedAuth } from './api.js';\nimport { DEFAULT_ENVIRONMENT } from './constants.js';\nimport { getTraceContextFromScope, getCurrentScope, getIsolationScope } from './currentScopes.js';\nimport { DEBUG_BUILD } from './debug-build.js';\nimport { createEventEnvelope, createSessionEnvelope } from './envelope.js';\nimport { setupIntegration, afterSetupIntegrations, setupIntegrations } from './integration.js';\nimport { _INTERNAL_flushLogsBuffer } from './logs/internal.js';\nimport { _INTERNAL_flushMetricsBuffer } from './metrics/internal.js';\nimport { updateSession } from './session.js';\nimport { getDynamicSamplingContextFromScope } from './tracing/dynamicSamplingContext.js';\nimport { createClientReportEnvelope } from './utils/clientreport.js';\nimport { debug } from './utils/debug-logger.js';\nimport { makeDsn, dsnToString } from './utils/dsn.js';\nimport { addItemToEnvelope, createAttachmentEnvelopeItem } from './utils/envelope.js';\nimport { getPossibleEventMessages } from './utils/eventUtils.js';\nimport { isPrimitive, isParameterizedString, isThenable, isPlainObject } from './utils/is.js';\nimport { merge } from './utils/merge.js';\nimport { uuid4, checkOrSetAlreadyCaught } from './utils/misc.js';\nimport { parseSampleRate } from './utils/parseSampleRate.js';\nimport { prepareEvent } from './utils/prepareEvent.js';\nimport { shouldIgnoreSpan, reparentChildSpans } from './utils/should-ignore-span.js';\nimport { showSpanDropWarning } from './utils/spanUtils.js';\nimport { rejectedSyncPromise } from './utils/syncpromise.js';\nimport { convertTransactionEventToSpanJson, convertSpanJsonToTransactionEvent } from './utils/transactionEvent.js';\n\n/* eslint-disable max-lines */\n\nconst ALREADY_SEEN_ERROR = \"Not capturing exception because it's already been captured.\";\nconst MISSING_RELEASE_FOR_SESSION_ERROR = 'Discarded session because of missing or non-string release';\n\nconst INTERNAL_ERROR_SYMBOL = Symbol.for('SentryInternalError');\nconst DO_NOT_SEND_EVENT_SYMBOL = Symbol.for('SentryDoNotSendEventError');\n\n// Default interval for flushing logs and metrics (5 seconds)\nconst DEFAULT_FLUSH_INTERVAL = 5000;\n\nfunction _makeInternalError(message) {\n return {\n message,\n [INTERNAL_ERROR_SYMBOL]: true,\n };\n}\n\nfunction _makeDoNotSendEventError(message) {\n return {\n message,\n [DO_NOT_SEND_EVENT_SYMBOL]: true,\n };\n}\n\nfunction _isInternalError(error) {\n return !!error && typeof error === 'object' && INTERNAL_ERROR_SYMBOL in error;\n}\n\nfunction _isDoNotSendEventError(error) {\n return !!error && typeof error === 'object' && DO_NOT_SEND_EVENT_SYMBOL in error;\n}\n\n/**\n * Sets up weight-based flushing for logs or metrics.\n * This helper function encapsulates the common pattern of:\n * 1. Tracking accumulated weight of items\n * 2. Flushing when weight exceeds threshold (800KB)\n * 3. Flushing after idle timeout if no new items arrive\n *\n * Uses closure variables to track weight and timeout state.\n */\nfunction setupWeightBasedFlushing\n\n(\n client,\n afterCaptureHook,\n flushHook,\n estimateSizeFn,\n flushFn,\n) {\n // Track weight and timeout in closure variables\n let weight = 0;\n let flushTimeout;\n\n // @ts-expect-error - TypeScript can't narrow generic hook types to match specific overloads, but we know this is type-safe\n client.on(flushHook, () => {\n weight = 0;\n clearTimeout(flushTimeout);\n });\n\n // @ts-expect-error - TypeScript can't narrow generic hook types to match specific overloads, but we know this is type-safe\n client.on(afterCaptureHook, (item) => {\n weight += estimateSizeFn(item);\n\n // We flush the buffer if it exceeds 0.8 MB\n // The weight is a rough estimate, so we flush way before the payload gets too big.\n if (weight >= 800000) {\n flushFn(client);\n } else {\n clearTimeout(flushTimeout);\n flushTimeout = setTimeout(() => {\n flushFn(client);\n }, DEFAULT_FLUSH_INTERVAL);\n }\n });\n\n client.on('flush', () => {\n flushFn(client);\n });\n}\n\n/**\n * Base implementation for all JavaScript SDK clients.\n *\n * Call the constructor with the corresponding options\n * specific to the client subclass. To access these options later, use\n * {@link Client.getOptions}.\n *\n * If a Dsn is specified in the options, it will be parsed and stored. Use\n * {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is\n * invalid, the constructor will throw a {@link SentryException}. Note that\n * without a valid Dsn, the SDK will not send any events to Sentry.\n *\n * Before sending an event, it is passed through\n * {@link Client._prepareEvent} to add SDK information and scope data\n * (breadcrumbs and context). To add more custom information, override this\n * method and extend the resulting prepared event.\n *\n * To issue automatically created events (e.g. via instrumentation), use\n * {@link Client.captureEvent}. It will prepare the event and pass it through\n * the callback lifecycle. To issue auto-breadcrumbs, use\n * {@link Client.addBreadcrumb}.\n *\n * @example\n * class NodeClient extends Client {\n * public constructor(options: NodeOptions) {\n * super(options);\n * }\n *\n * // ...\n * }\n */\nclass Client {\n /** Options passed to the SDK. */\n\n /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */\n\n /** Array of set up integrations. */\n\n /** Number of calls being processed */\n\n /** Holds flushable */\n\n // eslint-disable-next-line @typescript-eslint/ban-types\n\n /**\n * Initializes this client instance.\n *\n * @param options Options for the client.\n */\n constructor(options) {\n this._options = options;\n this._integrations = {};\n this._numProcessing = 0;\n this._outcomes = {};\n this._hooks = {};\n this._eventProcessors = [];\n\n if (options.dsn) {\n this._dsn = makeDsn(options.dsn);\n } else {\n DEBUG_BUILD && debug.warn('No DSN provided, client will not send events.');\n }\n\n if (this._dsn) {\n const url = getEnvelopeEndpointWithUrlEncodedAuth(\n this._dsn,\n options.tunnel,\n options._metadata ? options._metadata.sdk : undefined,\n );\n this._transport = options.transport({\n tunnel: this._options.tunnel,\n recordDroppedEvent: this.recordDroppedEvent.bind(this),\n ...options.transportOptions,\n url,\n });\n }\n\n // Setup log flushing with weight and timeout tracking\n if (this._options.enableLogs) {\n setupWeightBasedFlushing(this, 'afterCaptureLog', 'flushLogs', estimateLogSizeInBytes, _INTERNAL_flushLogsBuffer);\n }\n\n // Setup metric flushing with weight and timeout tracking\n if (this._options._experiments?.enableMetrics) {\n setupWeightBasedFlushing(\n this,\n 'afterCaptureMetric',\n 'flushMetrics',\n estimateMetricSizeInBytes,\n _INTERNAL_flushMetricsBuffer,\n );\n }\n }\n\n /**\n * Captures an exception event and sends it to Sentry.\n *\n * Unlike `captureException` exported from every SDK, this method requires that you pass it the current scope.\n */\n captureException(exception, hint, scope) {\n const eventId = uuid4();\n\n // ensure we haven't captured this very object before\n if (checkOrSetAlreadyCaught(exception)) {\n DEBUG_BUILD && debug.log(ALREADY_SEEN_ERROR);\n return eventId;\n }\n\n const hintWithEventId = {\n event_id: eventId,\n ...hint,\n };\n\n this._process(\n this.eventFromException(exception, hintWithEventId).then(event =>\n this._captureEvent(event, hintWithEventId, scope),\n ),\n );\n\n return hintWithEventId.event_id;\n }\n\n /**\n * Captures a message event and sends it to Sentry.\n *\n * Unlike `captureMessage` exported from every SDK, this method requires that you pass it the current scope.\n */\n captureMessage(\n message,\n level,\n hint,\n currentScope,\n ) {\n const hintWithEventId = {\n event_id: uuid4(),\n ...hint,\n };\n\n const eventMessage = isParameterizedString(message) ? message : String(message);\n\n const promisedEvent = isPrimitive(message)\n ? this.eventFromMessage(eventMessage, level, hintWithEventId)\n : this.eventFromException(message, hintWithEventId);\n\n this._process(promisedEvent.then(event => this._captureEvent(event, hintWithEventId, currentScope)));\n\n return hintWithEventId.event_id;\n }\n\n /**\n * Captures a manually created event and sends it to Sentry.\n *\n * Unlike `captureEvent` exported from every SDK, this method requires that you pass it the current scope.\n */\n captureEvent(event, hint, currentScope) {\n const eventId = uuid4();\n\n // ensure we haven't captured this very object before\n if (hint?.originalException && checkOrSetAlreadyCaught(hint.originalException)) {\n DEBUG_BUILD && debug.log(ALREADY_SEEN_ERROR);\n return eventId;\n }\n\n const hintWithEventId = {\n event_id: eventId,\n ...hint,\n };\n\n const sdkProcessingMetadata = event.sdkProcessingMetadata || {};\n const capturedSpanScope = sdkProcessingMetadata.capturedSpanScope;\n const capturedSpanIsolationScope = sdkProcessingMetadata.capturedSpanIsolationScope;\n\n this._process(\n this._captureEvent(event, hintWithEventId, capturedSpanScope || currentScope, capturedSpanIsolationScope),\n );\n\n return hintWithEventId.event_id;\n }\n\n /**\n * Captures a session.\n */\n captureSession(session) {\n this.sendSession(session);\n // After sending, we set init false to indicate it's not the first occurrence\n updateSession(session, { init: false });\n }\n\n /**\n * Create a cron monitor check in and send it to Sentry. This method is not available on all clients.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n * @param scope An optional scope containing event metadata.\n * @returns A string representing the id of the check in.\n */\n\n /**\n * Get the current Dsn.\n */\n getDsn() {\n return this._dsn;\n }\n\n /**\n * Get the current options.\n */\n getOptions() {\n return this._options;\n }\n\n /**\n * Get the SDK metadata.\n * @see SdkMetadata\n */\n getSdkMetadata() {\n return this._options._metadata;\n }\n\n /**\n * Returns the transport that is used by the client.\n * Please note that the transport gets lazy initialized so it will only be there once the first event has been sent.\n */\n getTransport() {\n return this._transport;\n }\n\n /**\n * Wait for all events to be sent or the timeout to expire, whichever comes first.\n *\n * @param timeout Maximum time in ms the client should wait for events to be flushed. Omitting this parameter will\n * cause the client to wait until all events are sent before resolving the promise.\n * @returns A promise that will resolve with `true` if all events are sent before the timeout, or `false` if there are\n * still events in the queue when the timeout is reached.\n */\n // @ts-expect-error - PromiseLike is a subset of Promise\n async flush(timeout) {\n const transport = this._transport;\n if (!transport) {\n return true;\n }\n\n this.emit('flush');\n\n const clientFinished = await this._isClientDoneProcessing(timeout);\n const transportFlushed = await transport.flush(timeout);\n\n return clientFinished && transportFlushed;\n }\n\n /**\n * Flush the event queue and set the client to `enabled = false`. See {@link Client.flush}.\n *\n * @param {number} timeout Maximum time in ms the client should wait before shutting down. Omitting this parameter will cause\n * the client to wait until all events are sent before disabling itself.\n * @returns {Promise} A promise which resolves to `true` if the flush completes successfully before the timeout, or `false` if\n * it doesn't.\n */\n // @ts-expect-error - PromiseLike is a subset of Promise\n async close(timeout) {\n const result = await this.flush(timeout);\n this.getOptions().enabled = false;\n this.emit('close');\n return result;\n }\n\n /**\n * Get all installed event processors.\n */\n getEventProcessors() {\n return this._eventProcessors;\n }\n\n /**\n * Adds an event processor that applies to any event processed by this client.\n */\n addEventProcessor(eventProcessor) {\n this._eventProcessors.push(eventProcessor);\n }\n\n /**\n * Initialize this client.\n * Call this after the client was set on a scope.\n */\n init() {\n if (\n this._isEnabled() ||\n // Force integrations to be setup even if no DSN was set when we have\n // Spotlight enabled. This is particularly important for browser as we\n // don't support the `spotlight` option there and rely on the users\n // adding the `spotlightBrowserIntegration()` to their integrations which\n // wouldn't get initialized with the check below when there's no DSN set.\n this._options.integrations.some(({ name }) => name.startsWith('Spotlight'))\n ) {\n this._setupIntegrations();\n }\n }\n\n /**\n * Gets an installed integration by its name.\n *\n * @returns {Integration|undefined} The installed integration or `undefined` if no integration with that `name` was installed.\n */\n getIntegrationByName(integrationName) {\n return this._integrations[integrationName] ;\n }\n\n /**\n * Add an integration to the client.\n * This can be used to e.g. lazy load integrations.\n * In most cases, this should not be necessary,\n * and you're better off just passing the integrations via `integrations: []` at initialization time.\n * However, if you find the need to conditionally load & add an integration, you can use `addIntegration` to do so.\n */\n addIntegration(integration) {\n const isAlreadyInstalled = this._integrations[integration.name];\n\n // This hook takes care of only installing if not already installed\n setupIntegration(this, integration, this._integrations);\n // Here we need to check manually to make sure to not run this multiple times\n if (!isAlreadyInstalled) {\n afterSetupIntegrations(this, [integration]);\n }\n }\n\n /**\n * Send a fully prepared event to Sentry.\n */\n sendEvent(event, hint = {}) {\n this.emit('beforeSendEvent', event, hint);\n\n let env = createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel);\n\n for (const attachment of hint.attachments || []) {\n env = addItemToEnvelope(env, createAttachmentEnvelopeItem(attachment));\n }\n\n // sendEnvelope should not throw\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n this.sendEnvelope(env).then(sendResponse => this.emit('afterSendEvent', event, sendResponse));\n }\n\n /**\n * Send a session or session aggregrates to Sentry.\n */\n sendSession(session) {\n // Backfill release and environment on session\n const { release: clientReleaseOption, environment: clientEnvironmentOption = DEFAULT_ENVIRONMENT } = this._options;\n if ('aggregates' in session) {\n const sessionAttrs = session.attrs || {};\n if (!sessionAttrs.release && !clientReleaseOption) {\n DEBUG_BUILD && debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n return;\n }\n sessionAttrs.release = sessionAttrs.release || clientReleaseOption;\n sessionAttrs.environment = sessionAttrs.environment || clientEnvironmentOption;\n session.attrs = sessionAttrs;\n } else {\n if (!session.release && !clientReleaseOption) {\n DEBUG_BUILD && debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n return;\n }\n session.release = session.release || clientReleaseOption;\n session.environment = session.environment || clientEnvironmentOption;\n }\n\n this.emit('beforeSendSession', session);\n\n const env = createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel);\n\n // sendEnvelope should not throw\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n this.sendEnvelope(env);\n }\n\n /**\n * Record on the client that an event got dropped (ie, an event that will not be sent to Sentry).\n */\n recordDroppedEvent(reason, category, count = 1) {\n if (this._options.sendClientReports) {\n // We want to track each category (error, transaction, session, replay_event) separately\n // but still keep the distinction between different type of outcomes.\n // We could use nested maps, but it's much easier to read and type this way.\n // A correct type for map-based implementation if we want to go that route\n // would be `Partial>>>`\n // With typescript 4.1 we could even use template literal types\n const key = `${reason}:${category}`;\n DEBUG_BUILD && debug.log(`Recording outcome: \"${key}\"${count > 1 ? ` (${count} times)` : ''}`);\n this._outcomes[key] = (this._outcomes[key] || 0) + count;\n }\n }\n\n /* eslint-disable @typescript-eslint/unified-signatures */\n /**\n * Register a callback for whenever a span is started.\n * Receives the span as argument.\n * @returns {() => void} A function that, when executed, removes the registered callback.\n */\n\n /**\n * Register a hook on this client.\n */\n on(hook, callback) {\n const hookCallbacks = (this._hooks[hook] = this._hooks[hook] || new Set());\n\n // Wrap the callback in a function so that registering the same callback instance multiple\n // times results in the callback being called multiple times.\n // @ts-expect-error - The `callback` type is correct and must be a function due to the\n // individual, specific overloads of this function.\n // eslint-disable-next-line @typescript-eslint/ban-types\n const uniqueCallback = (...args) => callback(...args);\n\n hookCallbacks.add(uniqueCallback);\n\n // This function returns a callback execution handler that, when invoked,\n // deregisters a callback. This is crucial for managing instances where callbacks\n // need to be unregistered to prevent self-referencing in callback closures,\n // ensuring proper garbage collection.\n return () => {\n hookCallbacks.delete(uniqueCallback);\n };\n }\n\n /** Fire a hook whenever a span starts. */\n\n /**\n * Emit a hook that was previously registered via `on()`.\n */\n emit(hook, ...rest) {\n const callbacks = this._hooks[hook];\n if (callbacks) {\n callbacks.forEach(callback => callback(...rest));\n }\n }\n\n /**\n * Send an envelope to Sentry.\n */\n // @ts-expect-error - PromiseLike is a subset of Promise\n async sendEnvelope(envelope) {\n this.emit('beforeEnvelope', envelope);\n\n if (this._isEnabled() && this._transport) {\n try {\n return await this._transport.send(envelope);\n } catch (reason) {\n DEBUG_BUILD && debug.error('Error while sending envelope:', reason);\n return {};\n }\n }\n\n DEBUG_BUILD && debug.error('Transport disabled');\n return {};\n }\n\n /* eslint-enable @typescript-eslint/unified-signatures */\n\n /** Setup integrations for this client. */\n _setupIntegrations() {\n const { integrations } = this._options;\n this._integrations = setupIntegrations(this, integrations);\n afterSetupIntegrations(this, integrations);\n }\n\n /** Updates existing session based on the provided event */\n _updateSessionFromEvent(session, event) {\n let crashed = event.level === 'fatal';\n let errored = false;\n const exceptions = event.exception?.values;\n\n if (exceptions) {\n errored = true;\n\n for (const ex of exceptions) {\n const mechanism = ex.mechanism;\n if (mechanism?.handled === false) {\n crashed = true;\n break;\n }\n }\n }\n\n // A session is updated and that session update is sent in only one of the two following scenarios:\n // 1. Session with non terminal status and 0 errors + an error occurred -> Will set error count to 1 and send update\n // 2. Session with non terminal status and 1 error + a crash occurred -> Will set status crashed and send update\n const sessionNonTerminal = session.status === 'ok';\n const shouldUpdateAndSend = (sessionNonTerminal && session.errors === 0) || (sessionNonTerminal && crashed);\n\n if (shouldUpdateAndSend) {\n updateSession(session, {\n ...(crashed && { status: 'crashed' }),\n errors: session.errors || Number(errored || crashed),\n });\n this.captureSession(session);\n }\n }\n\n /**\n * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying\n * \"no\" (resolving to `false`) in order to give the client a chance to potentially finish first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not\n * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and\n * `false` otherwise\n */\n async _isClientDoneProcessing(timeout) {\n let ticked = 0;\n\n // if no timeout is provided, we wait \"forever\" until everything is processed\n while (!timeout || ticked < timeout) {\n await new Promise(resolve => setTimeout(resolve, 1));\n\n if (!this._numProcessing) {\n return true;\n }\n ticked++;\n }\n\n return false;\n }\n\n /** Determines whether this SDK is enabled and a transport is present. */\n _isEnabled() {\n return this.getOptions().enabled !== false && this._transport !== undefined;\n }\n\n /**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param currentScope A scope containing event metadata.\n * @returns A new event with more information.\n */\n _prepareEvent(\n event,\n hint,\n currentScope,\n isolationScope,\n ) {\n const options = this.getOptions();\n const integrations = Object.keys(this._integrations);\n if (!hint.integrations && integrations?.length) {\n hint.integrations = integrations;\n }\n\n this.emit('preprocessEvent', event, hint);\n\n if (!event.type) {\n isolationScope.setLastEventId(event.event_id || hint.event_id);\n }\n\n return prepareEvent(options, event, hint, currentScope, this, isolationScope).then(evt => {\n if (evt === null) {\n return evt;\n }\n\n this.emit('postprocessEvent', evt, hint);\n\n evt.contexts = {\n trace: getTraceContextFromScope(currentScope),\n ...evt.contexts,\n };\n\n const dynamicSamplingContext = getDynamicSamplingContextFromScope(this, currentScope);\n\n evt.sdkProcessingMetadata = {\n dynamicSamplingContext,\n ...evt.sdkProcessingMetadata,\n };\n\n return evt;\n });\n }\n\n /**\n * Processes the event and logs an error in case of rejection\n * @param event\n * @param hint\n * @param scope\n */\n _captureEvent(\n event,\n hint = {},\n currentScope = getCurrentScope(),\n isolationScope = getIsolationScope(),\n ) {\n if (DEBUG_BUILD && isErrorEvent(event)) {\n debug.log(`Captured error event \\`${getPossibleEventMessages(event)[0] || ''}\\``);\n }\n\n return this._processEvent(event, hint, currentScope, isolationScope).then(\n finalEvent => {\n return finalEvent.event_id;\n },\n reason => {\n if (DEBUG_BUILD) {\n if (_isDoNotSendEventError(reason)) {\n debug.log(reason.message);\n } else if (_isInternalError(reason)) {\n debug.warn(reason.message);\n } else {\n debug.warn(reason);\n }\n }\n return undefined;\n },\n );\n }\n\n /**\n * Processes an event (either error or message) and sends it to Sentry.\n *\n * This also adds breadcrumbs and context information to the event. However,\n * platform specific meta data (such as the User's IP address) must be added\n * by the SDK implementor.\n *\n *\n * @param event The event to send to Sentry.\n * @param hint May contain additional information about the original exception.\n * @param currentScope A scope containing event metadata.\n * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send.\n */\n _processEvent(\n event,\n hint,\n currentScope,\n isolationScope,\n ) {\n const options = this.getOptions();\n const { sampleRate } = options;\n\n const isTransaction = isTransactionEvent(event);\n const isError = isErrorEvent(event);\n const eventType = event.type || 'error';\n const beforeSendLabel = `before send for type \\`${eventType}\\``;\n\n // 1.0 === 100% events are sent\n // 0.0 === 0% events are sent\n // Sampling for transaction happens somewhere else\n const parsedSampleRate = typeof sampleRate === 'undefined' ? undefined : parseSampleRate(sampleRate);\n if (isError && typeof parsedSampleRate === 'number' && Math.random() > parsedSampleRate) {\n this.recordDroppedEvent('sample_rate', 'error');\n return rejectedSyncPromise(\n _makeDoNotSendEventError(\n `Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`,\n ),\n );\n }\n\n const dataCategory = (eventType === 'replay_event' ? 'replay' : eventType) ;\n\n return this._prepareEvent(event, hint, currentScope, isolationScope)\n .then(prepared => {\n if (prepared === null) {\n this.recordDroppedEvent('event_processor', dataCategory);\n throw _makeDoNotSendEventError('An event processor returned `null`, will not send event.');\n }\n\n const isInternalException = hint.data && (hint.data ).__sentry__ === true;\n if (isInternalException) {\n return prepared;\n }\n\n const result = processBeforeSend(this, options, prepared, hint);\n return _validateBeforeSendResult(result, beforeSendLabel);\n })\n .then(processedEvent => {\n if (processedEvent === null) {\n this.recordDroppedEvent('before_send', dataCategory);\n if (isTransaction) {\n const spans = event.spans || [];\n // the transaction itself counts as one span, plus all the child spans that are added\n const spanCount = 1 + spans.length;\n this.recordDroppedEvent('before_send', 'span', spanCount);\n }\n throw _makeDoNotSendEventError(`${beforeSendLabel} returned \\`null\\`, will not send event.`);\n }\n\n const session = currentScope.getSession() || isolationScope.getSession();\n if (isError && session) {\n this._updateSessionFromEvent(session, processedEvent);\n }\n\n if (isTransaction) {\n const spanCountBefore = processedEvent.sdkProcessingMetadata?.spanCountBeforeProcessing || 0;\n const spanCountAfter = processedEvent.spans ? processedEvent.spans.length : 0;\n\n const droppedSpanCount = spanCountBefore - spanCountAfter;\n if (droppedSpanCount > 0) {\n this.recordDroppedEvent('before_send', 'span', droppedSpanCount);\n }\n }\n\n // None of the Sentry built event processor will update transaction name,\n // so if the transaction name has been changed by an event processor, we know\n // it has to come from custom event processor added by a user\n const transactionInfo = processedEvent.transaction_info;\n if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) {\n const source = 'custom';\n processedEvent.transaction_info = {\n ...transactionInfo,\n source,\n };\n }\n\n this.sendEvent(processedEvent, hint);\n return processedEvent;\n })\n .then(null, reason => {\n if (_isDoNotSendEventError(reason) || _isInternalError(reason)) {\n throw reason;\n }\n\n this.captureException(reason, {\n mechanism: {\n handled: false,\n type: 'internal',\n },\n data: {\n __sentry__: true,\n },\n originalException: reason,\n });\n throw _makeInternalError(\n `Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\\nReason: ${reason}`,\n );\n });\n }\n\n /**\n * Occupies the client with processing and event\n */\n _process(promise) {\n this._numProcessing++;\n void promise.then(\n value => {\n this._numProcessing--;\n return value;\n },\n reason => {\n this._numProcessing--;\n return reason;\n },\n );\n }\n\n /**\n * Clears outcomes on this client and returns them.\n */\n _clearOutcomes() {\n const outcomes = this._outcomes;\n this._outcomes = {};\n return Object.entries(outcomes).map(([key, quantity]) => {\n const [reason, category] = key.split(':') ;\n return {\n reason,\n category,\n quantity,\n };\n });\n }\n\n /**\n * Sends client reports as an envelope.\n */\n _flushOutcomes() {\n DEBUG_BUILD && debug.log('Flushing outcomes...');\n\n const outcomes = this._clearOutcomes();\n\n if (outcomes.length === 0) {\n DEBUG_BUILD && debug.log('No outcomes to send');\n return;\n }\n\n // This is really the only place where we want to check for a DSN and only send outcomes then\n if (!this._dsn) {\n DEBUG_BUILD && debug.log('No dsn provided, will not send outcomes');\n return;\n }\n\n DEBUG_BUILD && debug.log('Sending outcomes:', outcomes);\n\n const envelope = createClientReportEnvelope(outcomes, this._options.tunnel && dsnToString(this._dsn));\n\n // sendEnvelope should not throw\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n this.sendEnvelope(envelope);\n }\n\n /**\n * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n */\n\n}\n\n/**\n * Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so.\n */\nfunction _validateBeforeSendResult(\n beforeSendResult,\n beforeSendLabel,\n) {\n const invalidValueError = `${beforeSendLabel} must return \\`null\\` or a valid event.`;\n if (isThenable(beforeSendResult)) {\n return beforeSendResult.then(\n event => {\n if (!isPlainObject(event) && event !== null) {\n throw _makeInternalError(invalidValueError);\n }\n return event;\n },\n e => {\n throw _makeInternalError(`${beforeSendLabel} rejected with ${e}`);\n },\n );\n } else if (!isPlainObject(beforeSendResult) && beforeSendResult !== null) {\n throw _makeInternalError(invalidValueError);\n }\n return beforeSendResult;\n}\n\n/**\n * Process the matching `beforeSendXXX` callback.\n */\nfunction processBeforeSend(\n client,\n options,\n event,\n hint,\n) {\n const { beforeSend, beforeSendTransaction, beforeSendSpan, ignoreSpans } = options;\n let processedEvent = event;\n\n if (isErrorEvent(processedEvent) && beforeSend) {\n return beforeSend(processedEvent, hint);\n }\n\n if (isTransactionEvent(processedEvent)) {\n // Avoid processing if we don't have to\n if (beforeSendSpan || ignoreSpans) {\n // 1. Process root span\n const rootSpanJson = convertTransactionEventToSpanJson(processedEvent);\n\n // 1.1 If the root span should be ignored, drop the whole transaction\n if (ignoreSpans?.length && shouldIgnoreSpan(rootSpanJson, ignoreSpans)) {\n // dropping the whole transaction!\n return null;\n }\n\n // 1.2 If a `beforeSendSpan` callback is defined, process the root span\n if (beforeSendSpan) {\n const processedRootSpanJson = beforeSendSpan(rootSpanJson);\n if (!processedRootSpanJson) {\n showSpanDropWarning();\n } else {\n // update event with processed root span values\n processedEvent = merge(event, convertSpanJsonToTransactionEvent(processedRootSpanJson));\n }\n }\n\n // 2. Process child spans\n if (processedEvent.spans) {\n const processedSpans = [];\n\n const initialSpans = processedEvent.spans;\n\n for (const span of initialSpans) {\n // 2.a If the child span should be ignored, reparent it to the root span\n if (ignoreSpans?.length && shouldIgnoreSpan(span, ignoreSpans)) {\n reparentChildSpans(initialSpans, span);\n continue;\n }\n\n // 2.b If a `beforeSendSpan` callback is defined, process the child span\n if (beforeSendSpan) {\n const processedSpan = beforeSendSpan(span);\n if (!processedSpan) {\n showSpanDropWarning();\n processedSpans.push(span);\n } else {\n processedSpans.push(processedSpan);\n }\n } else {\n processedSpans.push(span);\n }\n }\n\n const droppedSpans = processedEvent.spans.length - processedSpans.length;\n if (droppedSpans) {\n client.recordDroppedEvent('before_send', 'span', droppedSpans);\n }\n\n processedEvent.spans = processedSpans;\n }\n }\n\n if (beforeSendTransaction) {\n if (processedEvent.spans) {\n // We store the # of spans before processing in SDK metadata,\n // so we can compare it afterwards to determine how many spans were dropped\n const spanCountBefore = processedEvent.spans.length;\n processedEvent.sdkProcessingMetadata = {\n ...event.sdkProcessingMetadata,\n spanCountBeforeProcessing: spanCountBefore,\n };\n }\n return beforeSendTransaction(processedEvent , hint);\n }\n }\n\n return processedEvent;\n}\n\nfunction isErrorEvent(event) {\n return event.type === undefined;\n}\n\nfunction isTransactionEvent(event) {\n return event.type === 'transaction';\n}\n\n/**\n * Estimate the size of a metric in bytes.\n *\n * @param metric - The metric to estimate the size of.\n * @returns The estimated size of the metric in bytes.\n */\nfunction estimateMetricSizeInBytes(metric) {\n let weight = 0;\n\n // Estimate byte size of 2 bytes per character. This is a rough estimate JS strings are stored as UTF-16.\n if (metric.name) {\n weight += metric.name.length * 2;\n }\n\n // Add weight for the value\n if (typeof metric.value === 'string') {\n weight += metric.value.length * 2;\n } else {\n weight += 8; // number\n }\n\n return weight + estimateAttributesSizeInBytes(metric.attributes);\n}\n\n/**\n * Estimate the size of a log in bytes.\n *\n * @param log - The log to estimate the size of.\n * @returns The estimated size of the log in bytes.\n */\nfunction estimateLogSizeInBytes(log) {\n let weight = 0;\n\n // Estimate byte size of 2 bytes per character. This is a rough estimate JS strings are stored as UTF-16.\n if (log.message) {\n weight += log.message.length * 2;\n }\n\n return weight + estimateAttributesSizeInBytes(log.attributes);\n}\n\n/**\n * Estimate the size of attributes in bytes.\n *\n * @param attributes - The attributes object to estimate the size of.\n * @returns The estimated size of the attributes in bytes.\n */\nfunction estimateAttributesSizeInBytes(attributes) {\n if (!attributes) {\n return 0;\n }\n\n let weight = 0;\n\n Object.values(attributes).forEach(value => {\n if (Array.isArray(value)) {\n weight += value.length * estimatePrimitiveSizeInBytes(value[0]);\n } else if (isPrimitive(value)) {\n weight += estimatePrimitiveSizeInBytes(value);\n } else {\n // For objects values, we estimate the size of the object as 100 bytes\n weight += 100;\n }\n });\n\n return weight;\n}\n\nfunction estimatePrimitiveSizeInBytes(value) {\n if (typeof value === 'string') {\n return value.length * 2;\n } else if (typeof value === 'number') {\n return 8;\n } else if (typeof value === 'boolean') {\n return 4;\n }\n\n return 0;\n}\n\nexport { Client };\n//# sourceMappingURL=client.js.map\n","import { SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD, SEMANTIC_ATTRIBUTE_URL_FULL, SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN } from '../semanticAttributes.js';\n\n// Curious about `thismessage:/`? See: https://www.rfc-editor.org/rfc/rfc2557.html\n// > When the methods above do not yield an absolute URI, a base URL\n// > of \"thismessage:/\" MUST be employed. This base URL has been\n// > defined for the sole purpose of resolving relative references\n// > within a multipart/related structure when no other base URI is\n// > specified.\n//\n// We need to provide a base URL to `parseStringToURLObject` because the fetch API gives us a\n// relative URL sometimes.\n//\n// This is the only case where we need to provide a base URL to `parseStringToURLObject`\n// because the relative URL is not valid on its own.\nconst DEFAULT_BASE_URL = 'thismessage:/';\n\n/**\n * Checks if the URL object is relative\n *\n * @param url - The URL object to check\n * @returns True if the URL object is relative, false otherwise\n */\nfunction isURLObjectRelative(url) {\n return 'isRelative' in url;\n}\n\n/**\n * Parses string to a URL object\n *\n * @param url - The URL to parse\n * @returns The parsed URL object or undefined if the URL is invalid\n */\nfunction parseStringToURLObject(url, urlBase) {\n const isRelative = url.indexOf('://') <= 0 && url.indexOf('//') !== 0;\n const base = urlBase ?? (isRelative ? DEFAULT_BASE_URL : undefined);\n try {\n // Use `canParse` to short-circuit the URL constructor if it's not a valid URL\n // This is faster than trying to construct the URL and catching the error\n // Node 20+, Chrome 120+, Firefox 115+, Safari 17+\n if ('canParse' in URL && !(URL ).canParse(url, base)) {\n return undefined;\n }\n\n const fullUrlObject = new URL(url, base);\n if (isRelative) {\n // Because we used a fake base URL, we need to return a relative URL object.\n // We cannot return anything about the origin, host, etc. because it will refer to the fake base URL.\n return {\n isRelative,\n pathname: fullUrlObject.pathname,\n search: fullUrlObject.search,\n hash: fullUrlObject.hash,\n };\n }\n return fullUrlObject;\n } catch {\n // empty body\n }\n\n return undefined;\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlStringFromUrlObject(url) {\n if (isURLObjectRelative(url)) {\n return url.pathname;\n }\n\n const newUrl = new URL(url);\n newUrl.search = '';\n newUrl.hash = '';\n if (['80', '443'].includes(newUrl.port)) {\n newUrl.port = '';\n }\n if (newUrl.password) {\n newUrl.password = '%filtered%';\n }\n if (newUrl.username) {\n newUrl.username = '%filtered%';\n }\n\n return newUrl.toString();\n}\n\nfunction getHttpSpanNameFromUrlObject(\n urlObject,\n kind,\n request,\n routeName,\n) {\n const method = request?.method?.toUpperCase() ?? 'GET';\n const route = routeName\n ? routeName\n : urlObject\n ? kind === 'client'\n ? getSanitizedUrlStringFromUrlObject(urlObject)\n : urlObject.pathname\n : '/';\n\n return `${method} ${route}`;\n}\n\n/**\n * Takes a parsed URL object and returns a set of attributes for the span\n * that represents the HTTP request for that url. This is used for both server\n * and client http spans.\n *\n * Follows https://opentelemetry.io/docs/specs/semconv/http/.\n *\n * @param urlObject - see {@link parseStringToURLObject}\n * @param kind - The type of HTTP operation (server or client)\n * @param spanOrigin - The origin of the span\n * @param request - The request object, see {@link PartialRequest}\n * @param routeName - The name of the route, must be low cardinality\n * @returns The span name and attributes for the HTTP operation\n */\nfunction getHttpSpanDetailsFromUrlObject(\n urlObject,\n kind,\n spanOrigin,\n request,\n routeName,\n) {\n const attributes = {\n [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: spanOrigin,\n [SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'url',\n };\n\n if (routeName) {\n // This is based on https://opentelemetry.io/docs/specs/semconv/http/http-spans/#name\n attributes[kind === 'server' ? 'http.route' : 'url.template'] = routeName;\n attributes[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n }\n\n if (request?.method) {\n attributes[SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD] = request.method.toUpperCase();\n }\n\n if (urlObject) {\n if (urlObject.search) {\n attributes['url.query'] = urlObject.search;\n }\n if (urlObject.hash) {\n attributes['url.fragment'] = urlObject.hash;\n }\n if (urlObject.pathname) {\n attributes['url.path'] = urlObject.pathname;\n if (urlObject.pathname === '/') {\n attributes[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n }\n }\n\n if (!isURLObjectRelative(urlObject)) {\n attributes[SEMANTIC_ATTRIBUTE_URL_FULL] = urlObject.href;\n if (urlObject.port) {\n attributes['url.port'] = urlObject.port;\n }\n if (urlObject.protocol) {\n attributes['url.scheme'] = urlObject.protocol;\n }\n if (urlObject.hostname) {\n attributes[kind === 'server' ? 'server.address' : 'url.domain'] = urlObject.hostname;\n }\n }\n }\n\n return [getHttpSpanNameFromUrlObject(urlObject, kind, request, routeName), attributes];\n}\n\n/**\n * Parses string form of URL into an object\n * // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B\n * // intentionally using regex and not href parsing trick because React Native and other\n * // environments where DOM might not be available\n * @returns parsed URL object\n */\nfunction parseUrl(url) {\n if (!url) {\n return {};\n }\n\n const match = url.match(/^(([^:/?#]+):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?$/);\n\n if (!match) {\n return {};\n }\n\n // coerce to undefined values to empty string so we don't get 'undefined'\n const query = match[6] || '';\n const fragment = match[8] || '';\n return {\n host: match[4],\n path: match[5],\n protocol: match[2],\n search: query,\n hash: fragment,\n relative: match[5] + query + fragment, // everything minus origin\n };\n}\n\n/**\n * Strip the query string and fragment off of a given URL or path (if present)\n *\n * @param urlPath Full URL or path, including possible query string and/or fragment\n * @returns URL or path without query string or fragment\n */\nfunction stripUrlQueryAndFragment(urlPath) {\n return (urlPath.split(/[?#]/, 1) )[0];\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlString(url) {\n const { protocol, host, path } = url;\n\n const filteredHost =\n host\n // Always filter out authority\n ?.replace(/^.*@/, '[filtered]:[filtered]@')\n // Don't show standard :80 (http) and :443 (https) ports to reduce the noise\n // TODO: Use new URL global if it exists\n .replace(/(:80)$/, '')\n .replace(/(:443)$/, '') || '';\n\n return `${protocol ? `${protocol}://` : ''}${filteredHost}${path}`;\n}\n\nexport { getHttpSpanDetailsFromUrlObject, getSanitizedUrlString, getSanitizedUrlStringFromUrlObject, isURLObjectRelative, parseStringToURLObject, parseUrl, stripUrlQueryAndFragment };\n//# sourceMappingURL=url.js.map\n","import { parseStringToURLObject, isURLObjectRelative } from './url.js';\n\n/**\n * Checks whether given url points to Sentry server\n *\n * @param url url to verify\n */\nfunction isSentryRequestUrl(url, client) {\n const dsn = client?.getDsn();\n const tunnel = client?.getOptions().tunnel;\n return checkDsn(url, dsn) || checkTunnel(url, tunnel);\n}\n\nfunction checkTunnel(url, tunnel) {\n if (!tunnel) {\n return false;\n }\n\n return removeTrailingSlash(url) === removeTrailingSlash(tunnel);\n}\n\nfunction checkDsn(url, dsn) {\n // Requests to Sentry's ingest endpoint must have a `sentry_key` in the query string\n // This is equivalent to the public_key which is required in the DSN\n // see https://develop.sentry.dev/sdk/overview/#parsing-the-dsn\n // Therefore, a request to the same host and with a `sentry_key` in the query string\n // can be considered a request to the ingest endpoint.\n const urlParts = parseStringToURLObject(url);\n if (!urlParts || isURLObjectRelative(urlParts)) {\n return false;\n }\n\n return dsn ? urlParts.host.includes(dsn.host) && /(^|&|\\?)sentry_key=/.test(urlParts.search) : false;\n}\n\nfunction removeTrailingSlash(str) {\n return str[str.length - 1] === '/' ? str.slice(0, -1) : str;\n}\n\nexport { isSentryRequestUrl };\n//# sourceMappingURL=isSentryRequestUrl.js.map\n","// By default, we want to infer the IP address, unless this is explicitly set to `null`\n// We do this after all other processing is done\n// If `ip_address` is explicitly set to `null` or a value, we leave it as is\n\n/**\n * @internal\n * @deprecated -- set ip inferral via via SDK metadata options on client instead.\n */\nfunction addAutoIpAddressToUser(objWithMaybeUser) {\n if (objWithMaybeUser.user?.ip_address === undefined) {\n objWithMaybeUser.user = {\n ...objWithMaybeUser.user,\n ip_address: '{{auto}}',\n };\n }\n}\n\n/**\n * @internal\n */\nfunction addAutoIpAddressToSession(session) {\n if ('aggregates' in session) {\n if (session.attrs?.['ip_address'] === undefined) {\n session.attrs = {\n ...session.attrs,\n ip_address: '{{auto}}',\n };\n }\n } else {\n if (session.ipAddress === undefined) {\n session.ipAddress = '{{auto}}';\n }\n }\n}\n\nexport { addAutoIpAddressToSession, addAutoIpAddressToUser };\n//# sourceMappingURL=ipAddress.js.map\n","import { SDK_VERSION } from './version.js';\n\n/**\n * A builder for the SDK metadata in the options for the SDK initialization.\n *\n * Note: This function is identical to `buildMetadata` in Remix and NextJS and SvelteKit.\n * We don't extract it for bundle size reasons.\n * @see https://github.com/getsentry/sentry-javascript/pull/7404\n * @see https://github.com/getsentry/sentry-javascript/pull/4196\n *\n * If you make changes to this function consider updating the others as well.\n *\n * @param options SDK options object that gets mutated\n * @param names list of package names\n */\nfunction applySdkMetadata(options, name, names = [name], source = 'npm') {\n const metadata = options._metadata || {};\n\n if (!metadata.sdk) {\n metadata.sdk = {\n name: `sentry.javascript.${name}`,\n packages: names.map(name => ({\n name: `${source}:@sentry/${name}`,\n version: SDK_VERSION,\n })),\n version: SDK_VERSION,\n };\n }\n\n options._metadata = metadata;\n}\n\nexport { applySdkMetadata };\n//# sourceMappingURL=sdkMetadata.js.map\n","import { getClient, getIsolationScope } from './currentScopes.js';\nimport { consoleSandbox } from './utils/debug-logger.js';\nimport { dateTimestampInSeconds } from './utils/time.js';\n\n/**\n * Default maximum number of breadcrumbs added to an event. Can be overwritten\n * with {@link Options.maxBreadcrumbs}.\n */\nconst DEFAULT_BREADCRUMBS = 100;\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on\n * user's actions prior to an error or crash.\n */\nfunction addBreadcrumb(breadcrumb, hint) {\n const client = getClient();\n const isolationScope = getIsolationScope();\n\n if (!client) return;\n\n const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } = client.getOptions();\n\n if (maxBreadcrumbs <= 0) return;\n\n const timestamp = dateTimestampInSeconds();\n const mergedBreadcrumb = { timestamp, ...breadcrumb };\n const finalBreadcrumb = beforeBreadcrumb\n ? consoleSandbox(() => beforeBreadcrumb(mergedBreadcrumb, hint))\n : mergedBreadcrumb;\n\n if (finalBreadcrumb === null) return;\n\n if (client.emit) {\n client.emit('beforeAddBreadcrumb', finalBreadcrumb, hint);\n }\n\n isolationScope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs);\n}\n\nexport { addBreadcrumb };\n//# sourceMappingURL=breadcrumbs.js.map\n","import { getClient } from '../currentScopes.js';\nimport { defineIntegration } from '../integration.js';\nimport { getOriginalFunction } from '../utils/object.js';\n\nlet originalFunctionToString;\n\nconst INTEGRATION_NAME = 'FunctionToString';\n\nconst SETUP_CLIENTS = new WeakMap();\n\nconst _functionToStringIntegration = (() => {\n return {\n name: INTEGRATION_NAME,\n setupOnce() {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n originalFunctionToString = Function.prototype.toString;\n\n // intrinsics (like Function.prototype) might be immutable in some environments\n // e.g. Node with --frozen-intrinsics, XS (an embedded JavaScript engine) or SES (a JavaScript proposal)\n try {\n Function.prototype.toString = function ( ...args) {\n const originalFunction = getOriginalFunction(this);\n const context =\n SETUP_CLIENTS.has(getClient() ) && originalFunction !== undefined ? originalFunction : this;\n return originalFunctionToString.apply(context, args);\n };\n } catch {\n // ignore errors here, just don't patch this\n }\n },\n setup(client) {\n SETUP_CLIENTS.set(client, true);\n },\n };\n}) ;\n\n/**\n * Patch toString calls to return proper name for wrapped functions.\n *\n * ```js\n * Sentry.init({\n * integrations: [\n * functionToStringIntegration(),\n * ],\n * });\n * ```\n */\nconst functionToStringIntegration = defineIntegration(_functionToStringIntegration);\n\nexport { functionToStringIntegration };\n//# sourceMappingURL=functiontostring.js.map\n","import { isInstanceOf } from './is.js';\n\n/**\n * Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter.\n */\nfunction applyAggregateErrorsToEvent(\n exceptionFromErrorImplementation,\n parser,\n key,\n limit,\n event,\n hint,\n) {\n if (!event.exception?.values || !hint || !isInstanceOf(hint.originalException, Error)) {\n return;\n }\n\n // Generally speaking the last item in `event.exception.values` is the exception originating from the original Error\n const originalException =\n event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : undefined;\n\n // We only create exception grouping if there is an exception in the event.\n if (originalException) {\n event.exception.values = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n hint.originalException ,\n key,\n event.exception.values,\n originalException,\n 0,\n );\n }\n}\n\nfunction aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n error,\n key,\n prevExceptions,\n exception,\n exceptionId,\n) {\n if (prevExceptions.length >= limit + 1) {\n return prevExceptions;\n }\n\n let newExceptions = [...prevExceptions];\n\n // Recursively call this function in order to walk down a chain of errors\n if (isInstanceOf(error[key], Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, error[key]);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n error[key],\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n\n // This will create exception grouping for AggregateErrors\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError\n if (Array.isArray(error.errors)) {\n error.errors.forEach((childError, i) => {\n if (isInstanceOf(childError, Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, childError);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n childError,\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n });\n }\n\n return newExceptions;\n}\n\nfunction applyExceptionGroupFieldsForParentException(exception, exceptionId) {\n exception.mechanism = {\n handled: true,\n type: 'auto.core.linked_errors',\n ...exception.mechanism,\n ...(exception.type === 'AggregateError' && { is_exception_group: true }),\n exception_id: exceptionId,\n };\n}\n\nfunction applyExceptionGroupFieldsForChildException(\n exception,\n source,\n exceptionId,\n parentId,\n) {\n exception.mechanism = {\n handled: true,\n ...exception.mechanism,\n type: 'chained',\n source,\n exception_id: exceptionId,\n parent_id: parentId,\n };\n}\n\nexport { applyAggregateErrorsToEvent };\n//# sourceMappingURL=aggregate-errors.js.map\n","import { CONSOLE_LEVELS, originalConsoleMethods } from '../utils/debug-logger.js';\nimport { fill } from '../utils/object.js';\nimport { GLOBAL_OBJ } from '../utils/worldwide.js';\nimport { addHandler, maybeInstrument, triggerHandlers } from './handlers.js';\n\n/**\n * Add an instrumentation handler for when a console.xxx method is called.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addConsoleInstrumentationHandler(handler) {\n const type = 'console';\n addHandler(type, handler);\n maybeInstrument(type, instrumentConsole);\n}\n\nfunction instrumentConsole() {\n if (!('console' in GLOBAL_OBJ)) {\n return;\n }\n\n CONSOLE_LEVELS.forEach(function (level) {\n if (!(level in GLOBAL_OBJ.console)) {\n return;\n }\n\n fill(GLOBAL_OBJ.console, level, function (originalConsoleMethod) {\n originalConsoleMethods[level] = originalConsoleMethod;\n\n return function (...args) {\n const handlerData = { args, level };\n triggerHandlers('console', handlerData);\n\n const log = originalConsoleMethods[level];\n log?.apply(GLOBAL_OBJ.console, args);\n };\n });\n });\n}\n\nexport { addConsoleInstrumentationHandler };\n//# sourceMappingURL=console.js.map\n","/**\n * Converts a string-based level into a `SeverityLevel`, normalizing it along the way.\n *\n * @param level String representation of desired `SeverityLevel`.\n * @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level.\n */\nfunction severityLevelFromString(level) {\n return (\n level === 'warn' ? 'warning' : ['fatal', 'error', 'warning', 'log', 'info', 'debug'].includes(level) ? level : 'log'\n ) ;\n}\n\nexport { severityLevelFromString };\n//# sourceMappingURL=severity.js.map\n","import { getClient, withScope } from '../currentScopes.js';\nimport { captureMessage, captureException } from '../exports.js';\nimport { addConsoleInstrumentationHandler } from '../instrument/console.js';\nimport { defineIntegration } from '../integration.js';\nimport { CONSOLE_LEVELS } from '../utils/debug-logger.js';\nimport { addExceptionMechanism } from '../utils/misc.js';\nimport { severityLevelFromString } from '../utils/severity.js';\nimport { safeJoin } from '../utils/string.js';\nimport { GLOBAL_OBJ } from '../utils/worldwide.js';\n\nconst INTEGRATION_NAME = 'CaptureConsole';\n\nconst _captureConsoleIntegration = ((options = {}) => {\n const levels = options.levels || CONSOLE_LEVELS;\n const handled = options.handled ?? true;\n\n return {\n name: INTEGRATION_NAME,\n setup(client) {\n if (!('console' in GLOBAL_OBJ)) {\n return;\n }\n\n addConsoleInstrumentationHandler(({ args, level }) => {\n if (getClient() !== client || !levels.includes(level)) {\n return;\n }\n\n consoleHandler(args, level, handled);\n });\n },\n };\n}) ;\n\n/**\n * Send Console API calls as Sentry Events.\n */\nconst captureConsoleIntegration = defineIntegration(_captureConsoleIntegration);\n\nfunction consoleHandler(args, level, handled) {\n const captureContext = {\n level: severityLevelFromString(level),\n extra: {\n arguments: args,\n },\n };\n\n withScope(scope => {\n scope.addEventProcessor(event => {\n event.logger = 'console';\n\n addExceptionMechanism(event, {\n handled,\n type: 'auto.core.capture_console',\n });\n\n return event;\n });\n\n if (level === 'assert') {\n if (!args[0]) {\n const message = `Assertion failed: ${safeJoin(args.slice(1), ' ') || 'console.assert'}`;\n scope.setExtra('arguments', args.slice(1));\n captureMessage(message, captureContext);\n }\n return;\n }\n\n const error = args.find(arg => arg instanceof Error);\n if (error) {\n captureException(error, captureContext);\n return;\n }\n\n const message = safeJoin(args, ' ');\n captureMessage(message, captureContext);\n });\n}\n\nexport { captureConsoleIntegration };\n//# sourceMappingURL=captureconsole.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { defineIntegration } from '../integration.js';\nimport { debug } from '../utils/debug-logger.js';\nimport { getFramesFromEvent } from '../utils/stacktrace.js';\n\nconst INTEGRATION_NAME = 'Dedupe';\n\nconst _dedupeIntegration = (() => {\n let previousEvent;\n\n return {\n name: INTEGRATION_NAME,\n processEvent(currentEvent) {\n // We want to ignore any non-error type events, e.g. transactions or replays\n // These should never be deduped, and also not be compared against as _previousEvent.\n if (currentEvent.type) {\n return currentEvent;\n }\n\n // Juuust in case something goes wrong\n try {\n if (_shouldDropEvent(currentEvent, previousEvent)) {\n DEBUG_BUILD && debug.warn('Event dropped due to being a duplicate of previously captured event.');\n return null;\n }\n } catch {} // eslint-disable-line no-empty\n\n return (previousEvent = currentEvent);\n },\n };\n}) ;\n\n/**\n * Deduplication filter.\n */\nconst dedupeIntegration = defineIntegration(_dedupeIntegration);\n\n/** only exported for tests. */\nfunction _shouldDropEvent(currentEvent, previousEvent) {\n if (!previousEvent) {\n return false;\n }\n\n if (_isSameMessageEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n if (_isSameExceptionEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n return false;\n}\n\nfunction _isSameMessageEvent(currentEvent, previousEvent) {\n const currentMessage = currentEvent.message;\n const previousMessage = previousEvent.message;\n\n // If neither event has a message property, they were both exceptions, so bail out\n if (!currentMessage && !previousMessage) {\n return false;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentMessage && !previousMessage) || (!currentMessage && previousMessage)) {\n return false;\n }\n\n if (currentMessage !== previousMessage) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\nfunction _isSameExceptionEvent(currentEvent, previousEvent) {\n const previousException = _getExceptionFromEvent(previousEvent);\n const currentException = _getExceptionFromEvent(currentEvent);\n\n if (!previousException || !currentException) {\n return false;\n }\n\n if (previousException.type !== currentException.type || previousException.value !== currentException.value) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\nfunction _isSameStacktrace(currentEvent, previousEvent) {\n let currentFrames = getFramesFromEvent(currentEvent);\n let previousFrames = getFramesFromEvent(previousEvent);\n\n // If neither event has a stacktrace, they are assumed to be the same\n if (!currentFrames && !previousFrames) {\n return true;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentFrames && !previousFrames) || (!currentFrames && previousFrames)) {\n return false;\n }\n\n currentFrames = currentFrames ;\n previousFrames = previousFrames ;\n\n // If number of frames differ, they are not the same\n if (previousFrames.length !== currentFrames.length) {\n return false;\n }\n\n // Otherwise, compare the two\n for (let i = 0; i < previousFrames.length; i++) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const frameA = previousFrames[i];\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const frameB = currentFrames[i];\n\n if (\n frameA.filename !== frameB.filename ||\n frameA.lineno !== frameB.lineno ||\n frameA.colno !== frameB.colno ||\n frameA.function !== frameB.function\n ) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction _isSameFingerprint(currentEvent, previousEvent) {\n let currentFingerprint = currentEvent.fingerprint;\n let previousFingerprint = previousEvent.fingerprint;\n\n // If neither event has a fingerprint, they are assumed to be the same\n if (!currentFingerprint && !previousFingerprint) {\n return true;\n }\n\n // If only one event has a fingerprint, but not the other one, they are not the same\n if ((currentFingerprint && !previousFingerprint) || (!currentFingerprint && previousFingerprint)) {\n return false;\n }\n\n currentFingerprint = currentFingerprint ;\n previousFingerprint = previousFingerprint ;\n\n // Otherwise, compare the two\n try {\n return !!(currentFingerprint.join('') === previousFingerprint.join(''));\n } catch {\n return false;\n }\n}\n\nfunction _getExceptionFromEvent(event) {\n return event.exception?.values?.[0];\n}\n\nexport { _shouldDropEvent, dedupeIntegration };\n//# sourceMappingURL=dedupe.js.map\n","/**\n * Determine a breadcrumb's log level (only `warning` or `error`) based on an HTTP status code.\n */\nfunction getBreadcrumbLogLevelFromHttpStatusCode(statusCode) {\n // NOTE: undefined defaults to 'info' in Sentry\n if (statusCode === undefined) {\n return undefined;\n } else if (statusCode >= 400 && statusCode < 500) {\n return 'warning';\n } else if (statusCode >= 500) {\n return 'error';\n } else {\n return undefined;\n }\n}\n\nexport { getBreadcrumbLogLevelFromHttpStatusCode };\n//# sourceMappingURL=breadcrumb-log-level.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { debug } from './debug-logger.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nconst WINDOW = GLOBAL_OBJ ;\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsErrorEvent() {\n try {\n new ErrorEvent('');\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMError() {\n try {\n // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n // 1 argument required, but only 0 present.\n // @ts-expect-error It really needs 1 argument, not 0.\n new DOMError('');\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMException() {\n try {\n new DOMException('');\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsHistory() {\n return 'history' in WINDOW && !!WINDOW.history;\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nconst supportsFetch = _isFetchSupported;\n\nfunction _isFetchSupported() {\n if (!('fetch' in WINDOW)) {\n return false;\n }\n\n try {\n new Headers();\n new Request('http://www.example.com');\n new Response();\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * isNative checks if the given function is a native implementation\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction isNativeFunction(func) {\n return func && /^function\\s+\\w+\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nfunction supportsNativeFetch() {\n if (typeof EdgeRuntime === 'string') {\n return true;\n }\n\n if (!_isFetchSupported()) {\n return false;\n }\n\n // Fast path to avoid DOM I/O\n // eslint-disable-next-line @typescript-eslint/unbound-method\n if (isNativeFunction(WINDOW.fetch)) {\n return true;\n }\n\n // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n // so create a \"pure\" iframe to see if that has native fetch\n let result = false;\n const doc = WINDOW.document;\n // eslint-disable-next-line deprecation/deprecation\n if (doc && typeof (doc.createElement ) === 'function') {\n try {\n const sandbox = doc.createElement('iframe');\n sandbox.hidden = true;\n doc.head.appendChild(sandbox);\n if (sandbox.contentWindow?.fetch) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n result = isNativeFunction(sandbox.contentWindow.fetch);\n }\n doc.head.removeChild(sandbox);\n } catch (err) {\n DEBUG_BUILD && debug.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n }\n }\n\n return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsReportingObserver() {\n return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nfunction supportsReferrerPolicy() {\n // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n // (see https://caniuse.com/#feat=referrer-policy),\n // it doesn't. And it throws an exception instead of ignoring this parameter...\n // REF: https://github.com/getsentry/raven-js/issues/1233\n\n if (!_isFetchSupported()) {\n return false;\n }\n\n try {\n new Request('_', {\n referrerPolicy: 'origin' ,\n });\n return true;\n } catch {\n return false;\n }\n}\n\nexport { isNativeFunction, supportsDOMError, supportsDOMException, supportsErrorEvent, supportsFetch, supportsHistory, supportsNativeFetch, supportsReferrerPolicy, supportsReportingObserver };\n//# sourceMappingURL=supports.js.map\n","import { isError, isRequest } from '../utils/is.js';\nimport { fill, addNonEnumerableProperty } from '../utils/object.js';\nimport { supportsNativeFetch } from '../utils/supports.js';\nimport { timestampInSeconds } from '../utils/time.js';\nimport { GLOBAL_OBJ } from '../utils/worldwide.js';\nimport { addHandler, maybeInstrument, triggerHandlers } from './handlers.js';\n\n/**\n * Add an instrumentation handler for when a fetch request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addFetchInstrumentationHandler(\n handler,\n skipNativeFetchCheck,\n) {\n const type = 'fetch';\n addHandler(type, handler);\n maybeInstrument(type, () => instrumentFetch(undefined, skipNativeFetchCheck));\n}\n\n/**\n * Add an instrumentation handler for long-lived fetch requests, like consuming server-sent events (SSE) via fetch.\n * The handler will resolve the request body and emit the actual `endTimestamp`, so that the\n * span can be updated accordingly.\n *\n * Only used internally\n * @hidden\n */\nfunction addFetchEndInstrumentationHandler(handler) {\n const type = 'fetch-body-resolved';\n addHandler(type, handler);\n maybeInstrument(type, () => instrumentFetch(streamHandler));\n}\n\nfunction instrumentFetch(onFetchResolved, skipNativeFetchCheck = false) {\n if (skipNativeFetchCheck && !supportsNativeFetch()) {\n return;\n }\n\n fill(GLOBAL_OBJ, 'fetch', function (originalFetch) {\n return function (...args) {\n // We capture the error right here and not in the Promise error callback because Safari (and probably other\n // browsers too) will wipe the stack trace up to this point, only leaving us with this file which is useless.\n\n // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n // it means the error, that was caused by your fetch call did not\n // have a stack trace, so the SDK backfilled the stack trace so\n // you can see which fetch call failed.\n const virtualError = new Error();\n\n const { method, url } = parseFetchArgs(args);\n const handlerData = {\n args,\n fetchData: {\n method,\n url,\n },\n startTimestamp: timestampInSeconds() * 1000,\n // // Adding the error to be able to fingerprint the failed fetch event in HttpClient instrumentation\n virtualError,\n headers: getHeadersFromFetchArgs(args),\n };\n\n // if there is no callback, fetch is instrumented directly\n if (!onFetchResolved) {\n triggerHandlers('fetch', {\n ...handlerData,\n });\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return originalFetch.apply(GLOBAL_OBJ, args).then(\n async (response) => {\n if (onFetchResolved) {\n onFetchResolved(response);\n } else {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: timestampInSeconds() * 1000,\n response,\n });\n }\n\n return response;\n },\n (error) => {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: timestampInSeconds() * 1000,\n error,\n });\n\n if (isError(error) && error.stack === undefined) {\n // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n // it means the error, that was caused by your fetch call did not\n // have a stack trace, so the SDK backfilled the stack trace so\n // you can see which fetch call failed.\n error.stack = virtualError.stack;\n addNonEnumerableProperty(error, 'framesToPop', 1);\n }\n\n // We enhance the not-so-helpful \"Failed to fetch\" error messages with the host\n // Possible messages we handle here:\n // * \"Failed to fetch\" (chromium)\n // * \"Load failed\" (webkit)\n // * \"NetworkError when attempting to fetch resource.\" (firefox)\n if (\n error instanceof TypeError &&\n (error.message === 'Failed to fetch' ||\n error.message === 'Load failed' ||\n error.message === 'NetworkError when attempting to fetch resource.')\n ) {\n try {\n const url = new URL(handlerData.fetchData.url);\n error.message = `${error.message} (${url.host})`;\n } catch {\n // ignore it if errors happen here\n }\n }\n\n // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n // it means the sentry.javascript SDK caught an error invoking your application code.\n // This is expected behavior and NOT indicative of a bug with sentry.javascript.\n throw error;\n },\n );\n };\n });\n}\n\nasync function resolveResponse(res, onFinishedResolving) {\n if (res?.body) {\n const body = res.body;\n const responseReader = body.getReader();\n\n // Define a maximum duration after which we just cancel\n const maxFetchDurationTimeout = setTimeout(\n () => {\n body.cancel().then(null, () => {\n // noop\n });\n },\n 90 * 1000, // 90s\n );\n\n let readingActive = true;\n while (readingActive) {\n let chunkTimeout;\n try {\n // abort reading if read op takes more than 5s\n chunkTimeout = setTimeout(() => {\n body.cancel().then(null, () => {\n // noop on error\n });\n }, 5000);\n\n // This .read() call will reject/throw when we abort due to timeouts through `body.cancel()`\n const { done } = await responseReader.read();\n\n clearTimeout(chunkTimeout);\n\n if (done) {\n onFinishedResolving();\n readingActive = false;\n }\n } catch {\n readingActive = false;\n } finally {\n clearTimeout(chunkTimeout);\n }\n }\n\n clearTimeout(maxFetchDurationTimeout);\n\n responseReader.releaseLock();\n body.cancel().then(null, () => {\n // noop on error\n });\n }\n}\n\nfunction streamHandler(response) {\n // clone response for awaiting stream\n let clonedResponseForResolving;\n try {\n clonedResponseForResolving = response.clone();\n } catch {\n return;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n resolveResponse(clonedResponseForResolving, () => {\n triggerHandlers('fetch-body-resolved', {\n endTimestamp: timestampInSeconds() * 1000,\n response,\n });\n });\n}\n\nfunction hasProp(obj, prop) {\n return !!obj && typeof obj === 'object' && !!(obj )[prop];\n}\n\nfunction getUrlFromResource(resource) {\n if (typeof resource === 'string') {\n return resource;\n }\n\n if (!resource) {\n return '';\n }\n\n if (hasProp(resource, 'url')) {\n return resource.url;\n }\n\n if (resource.toString) {\n return resource.toString();\n }\n\n return '';\n}\n\n/**\n * Parses the fetch arguments to find the used Http method and the url of the request.\n * Exported for tests only.\n */\nfunction parseFetchArgs(fetchArgs) {\n if (fetchArgs.length === 0) {\n return { method: 'GET', url: '' };\n }\n\n if (fetchArgs.length === 2) {\n const [url, options] = fetchArgs ;\n\n return {\n url: getUrlFromResource(url),\n method: hasProp(options, 'method') ? String(options.method).toUpperCase() : 'GET',\n };\n }\n\n const arg = fetchArgs[0];\n return {\n url: getUrlFromResource(arg ),\n method: hasProp(arg, 'method') ? String(arg.method).toUpperCase() : 'GET',\n };\n}\n\nfunction getHeadersFromFetchArgs(fetchArgs) {\n const [requestArgument, optionsArgument] = fetchArgs;\n\n try {\n if (\n typeof optionsArgument === 'object' &&\n optionsArgument !== null &&\n 'headers' in optionsArgument &&\n optionsArgument.headers\n ) {\n return new Headers(optionsArgument.headers );\n }\n\n if (isRequest(requestArgument)) {\n return new Headers(requestArgument.headers);\n }\n } catch {\n // noop\n }\n\n return;\n}\n\nexport { addFetchEndInstrumentationHandler, addFetchInstrumentationHandler, parseFetchArgs };\n//# sourceMappingURL=fetch.js.map\n","/*\n * This module exists for optimizations in the build process through rollup and terser. We define some global\n * constants, which can be overridden during build. By guarding certain pieces of code with functions that return these\n * constants, we can control whether or not they appear in the final bundle. (Any code guarded by a false condition will\n * never run, and will hence be dropped during treeshaking.) The two primary uses for this are stripping out calls to\n * `debug` and preventing node-related code from appearing in browser bundles.\n *\n * Attention:\n * This file should not be used to define constants/flags that are intended to be used for tree-shaking conducted by\n * users. These flags should live in their respective packages, as we identified user tooling (specifically webpack)\n * having issues tree-shaking these constants across package boundaries.\n * An example for this is the __SENTRY_DEBUG__ constant. It is declared in each package individually because we want\n * users to be able to shake away expressions that it guards.\n */\n\n/**\n * Figures out if we're building a browser bundle.\n *\n * @returns true if this is a browser bundle build.\n */\nfunction isBrowserBundle() {\n return typeof __SENTRY_BROWSER_BUNDLE__ !== 'undefined' && !!__SENTRY_BROWSER_BUNDLE__;\n}\n\n/**\n * Get source of SDK.\n */\nfunction getSDKSource() {\n // This comment is used to identify this line in the CDN bundle build step and replace this with \"return 'cdn';\"\n /* __SENTRY_SDK_SOURCE__ */ return 'npm';\n}\n\nexport { getSDKSource, isBrowserBundle };\n//# sourceMappingURL=env.js.map\n","import { GLOBAL_OBJ, getOriginalFunction, markFunctionWrapped, addNonEnumerableProperty, withScope, addExceptionTypeValue, addExceptionMechanism, captureException, getLocationHref } from '@sentry/core';\n\nconst WINDOW = GLOBAL_OBJ ;\n\nlet ignoreOnError = 0;\n\n/**\n * @hidden\n */\nfunction shouldIgnoreOnError() {\n return ignoreOnError > 0;\n}\n\n/**\n * @hidden\n */\nfunction ignoreNextOnError() {\n // onerror should trigger before setTimeout\n ignoreOnError++;\n setTimeout(() => {\n ignoreOnError--;\n });\n}\n\n// eslint-disable-next-line @typescript-eslint/ban-types\n\n/**\n * Instruments the given function and sends an event to Sentry every time the\n * function throws an exception.\n *\n * @param fn A function to wrap. It is generally safe to pass an unbound function, because the returned wrapper always\n * has a correct `this` context.\n * @returns The wrapped function.\n * @hidden\n */\nfunction wrap(\n fn,\n options\n\n = {},\n) {\n // for future readers what this does is wrap a function and then create\n // a bi-directional wrapping between them.\n //\n // example: wrapped = wrap(original);\n // original.__sentry_wrapped__ -> wrapped\n // wrapped.__sentry_original__ -> original\n\n function isFunction(fn) {\n return typeof fn === 'function';\n }\n\n if (!isFunction(fn)) {\n return fn;\n }\n\n try {\n // if we're dealing with a function that was previously wrapped, return\n // the original wrapper.\n const wrapper = (fn ).__sentry_wrapped__;\n if (wrapper) {\n if (typeof wrapper === 'function') {\n return wrapper;\n } else {\n // If we find that the `__sentry_wrapped__` function is not a function at the time of accessing it, it means\n // that something messed with it. In that case we want to return the originally passed function.\n return fn;\n }\n }\n\n // We don't wanna wrap it twice\n if (getOriginalFunction(fn)) {\n return fn;\n }\n } catch {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n // Bail on wrapping and return the function as-is (defers to window.onerror).\n return fn;\n }\n\n // Wrap the function itself\n // It is important that `sentryWrapped` is not an arrow function to preserve the context of `this`\n const sentryWrapped = function ( ...args) {\n try {\n // Also wrap arguments that are themselves functions\n const wrappedArguments = args.map(arg => wrap(arg, options));\n\n // Attempt to invoke user-land function\n // NOTE: If you are a Sentry user, and you are seeing this stack frame, it\n // means the sentry.javascript SDK caught an error invoking your application code. This\n // is expected behavior and NOT indicative of a bug with sentry.javascript.\n return fn.apply(this, wrappedArguments);\n } catch (ex) {\n ignoreNextOnError();\n\n withScope(scope => {\n scope.addEventProcessor(event => {\n if (options.mechanism) {\n addExceptionTypeValue(event, undefined, undefined);\n addExceptionMechanism(event, options.mechanism);\n }\n\n event.extra = {\n ...event.extra,\n arguments: args,\n };\n\n return event;\n });\n\n // no need to add a mechanism here, we already add it via an event processor above\n captureException(ex);\n });\n\n throw ex;\n }\n } ;\n\n // Wrap the wrapped function in a proxy, to ensure any other properties of the original function remain available\n try {\n for (const property in fn) {\n if (Object.prototype.hasOwnProperty.call(fn, property)) {\n sentryWrapped[property ] = fn[property ];\n }\n }\n } catch {\n // Accessing some objects may throw\n // ref: https://github.com/getsentry/sentry-javascript/issues/1168\n }\n\n // Signal that this function has been wrapped/filled already\n // for both debugging and to prevent it to being wrapped/filled twice\n markFunctionWrapped(sentryWrapped, fn);\n\n addNonEnumerableProperty(fn, '__sentry_wrapped__', sentryWrapped);\n\n // Restore original function name (not all browsers allow that)\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const descriptor = Object.getOwnPropertyDescriptor(sentryWrapped, 'name');\n if (descriptor.configurable) {\n Object.defineProperty(sentryWrapped, 'name', {\n get() {\n return fn.name;\n },\n });\n }\n } catch {\n // This may throw if e.g. the descriptor does not exist, or a browser does not allow redefining `name`.\n // to save some bytes we simply try-catch this\n }\n\n return sentryWrapped;\n}\n\n/**\n * Get HTTP request data from the current page.\n */\nfunction getHttpRequestData() {\n // grab as much info as exists and add it to the event\n const url = getLocationHref();\n const { referrer } = WINDOW.document || {};\n const { userAgent } = WINDOW.navigator || {};\n\n const headers = {\n ...(referrer && { Referer: referrer }),\n ...(userAgent && { 'User-Agent': userAgent }),\n };\n const request = {\n url,\n headers,\n };\n\n return request;\n}\n\nexport { WINDOW, getHttpRequestData, ignoreNextOnError, shouldIgnoreOnError, wrap };\n//# sourceMappingURL=helpers.js.map\n","import { isErrorEvent, isDOMError, isDOMException, addExceptionTypeValue, isError, isPlainObject, isEvent, addExceptionMechanism, isParameterizedString, getClient, normalizeToSize, extractExceptionKeysForMessage, resolvedSyncPromise } from '@sentry/core';\n\n/**\n * This function creates an exception from a JavaScript Error\n */\nfunction exceptionFromError(stackParser, ex) {\n // Get the frames first since Opera can lose the stack if we touch anything else first\n const frames = parseStackFrames(stackParser, ex);\n\n const exception = {\n type: extractType(ex),\n value: extractMessage(ex),\n };\n\n if (frames.length) {\n exception.stacktrace = { frames };\n }\n\n if (exception.type === undefined && exception.value === '') {\n exception.value = 'Unrecoverable error caught';\n }\n\n return exception;\n}\n\nfunction eventFromPlainObject(\n stackParser,\n exception,\n syntheticException,\n isUnhandledRejection,\n) {\n const client = getClient();\n const normalizeDepth = client?.getOptions().normalizeDepth;\n\n // If we can, we extract an exception from the object properties\n const errorFromProp = getErrorPropertyFromObject(exception);\n\n const extra = {\n __serialized__: normalizeToSize(exception, normalizeDepth),\n };\n\n if (errorFromProp) {\n return {\n exception: {\n values: [exceptionFromError(stackParser, errorFromProp)],\n },\n extra,\n };\n }\n\n const event = {\n exception: {\n values: [\n {\n type: isEvent(exception) ? exception.constructor.name : isUnhandledRejection ? 'UnhandledRejection' : 'Error',\n value: getNonErrorObjectExceptionValue(exception, { isUnhandledRejection }),\n } ,\n ],\n },\n extra,\n } ;\n\n if (syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n // event.exception.values[0] has been set above\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n event.exception.values[0].stacktrace = { frames };\n }\n }\n\n return event;\n}\n\nfunction eventFromError(stackParser, ex) {\n return {\n exception: {\n values: [exceptionFromError(stackParser, ex)],\n },\n };\n}\n\n/** Parses stack frames from an error */\nfunction parseStackFrames(\n stackParser,\n ex,\n) {\n // Access and store the stacktrace property before doing ANYTHING\n // else to it because Opera is not very good at providing it\n // reliably in other circumstances.\n const stacktrace = ex.stacktrace || ex.stack || '';\n\n const skipLines = getSkipFirstStackStringLines(ex);\n const framesToPop = getPopFirstTopFrames(ex);\n\n try {\n return stackParser(stacktrace, skipLines, framesToPop);\n } catch {\n // no-empty\n }\n\n return [];\n}\n\n// Based on our own mapping pattern - https://github.com/getsentry/sentry/blob/9f08305e09866c8bd6d0c24f5b0aabdd7dd6c59c/src/sentry/lang/javascript/errormapping.py#L83-L108\nconst reactMinifiedRegexp = /Minified React error #\\d+;/i;\n\n/**\n * Certain known React errors contain links that would be falsely\n * parsed as frames. This function check for these errors and\n * returns number of the stack string lines to skip.\n */\nfunction getSkipFirstStackStringLines(ex) {\n if (ex && reactMinifiedRegexp.test(ex.message)) {\n return 1;\n }\n\n return 0;\n}\n\n/**\n * If error has `framesToPop` property, it means that the\n * creator tells us the first x frames will be useless\n * and should be discarded. Typically error from wrapper function\n * which don't point to the actual location in the developer's code.\n *\n * Example: https://github.com/zertosh/invariant/blob/master/invariant.js#L46\n */\nfunction getPopFirstTopFrames(ex) {\n if (typeof ex.framesToPop === 'number') {\n return ex.framesToPop;\n }\n\n return 0;\n}\n\n// https://developer.mozilla.org/en-US/docs/WebAssembly/JavaScript_interface/Exception\n// @ts-expect-error - WebAssembly.Exception is a valid class\nfunction isWebAssemblyException(exception) {\n // Check for support\n // @ts-expect-error - WebAssembly.Exception is a valid class\n if (typeof WebAssembly !== 'undefined' && typeof WebAssembly.Exception !== 'undefined') {\n // @ts-expect-error - WebAssembly.Exception is a valid class\n return exception instanceof WebAssembly.Exception;\n } else {\n return false;\n }\n}\n\n/**\n * Extracts from errors what we use as the exception `type` in error events.\n *\n * Usually, this is the `name` property on Error objects but WASM errors need to be treated differently.\n */\nfunction extractType(ex) {\n const name = ex?.name;\n\n // The name for WebAssembly.Exception Errors needs to be extracted differently.\n // Context: https://github.com/getsentry/sentry-javascript/issues/13787\n if (!name && isWebAssemblyException(ex)) {\n // Emscripten sets array[type, message] to the \"message\" property on the WebAssembly.Exception object\n const hasTypeInMessage = ex.message && Array.isArray(ex.message) && ex.message.length == 2;\n return hasTypeInMessage ? ex.message[0] : 'WebAssembly.Exception';\n }\n\n return name;\n}\n\n/**\n * There are cases where stacktrace.message is an Event object\n * https://github.com/getsentry/sentry-javascript/issues/1949\n * In this specific case we try to extract stacktrace.message.error.message\n */\nfunction extractMessage(ex) {\n const message = ex?.message;\n\n if (isWebAssemblyException(ex)) {\n // For Node 18, Emscripten sets array[type, message] to the \"message\" property on the WebAssembly.Exception object\n if (Array.isArray(ex.message) && ex.message.length == 2) {\n return ex.message[1];\n }\n return 'wasm exception';\n }\n\n if (!message) {\n return 'No error message';\n }\n\n if (message.error && typeof message.error.message === 'string') {\n return message.error.message;\n }\n\n return message;\n}\n\n/**\n * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n * @hidden\n */\nfunction eventFromException(\n stackParser,\n exception,\n hint,\n attachStacktrace,\n) {\n const syntheticException = hint?.syntheticException || undefined;\n const event = eventFromUnknownInput(stackParser, exception, syntheticException, attachStacktrace);\n addExceptionMechanism(event); // defaults to { type: 'generic', handled: true }\n event.level = 'error';\n if (hint?.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nfunction eventFromMessage(\n stackParser,\n message,\n level = 'info',\n hint,\n attachStacktrace,\n) {\n const syntheticException = hint?.syntheticException || undefined;\n const event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n event.level = level;\n if (hint?.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * @hidden\n */\nfunction eventFromUnknownInput(\n stackParser,\n exception,\n syntheticException,\n attachStacktrace,\n isUnhandledRejection,\n) {\n let event;\n\n if (isErrorEvent(exception ) && (exception ).error) {\n // If it is an ErrorEvent with `error` property, extract it to get actual Error\n const errorEvent = exception ;\n return eventFromError(stackParser, errorEvent.error );\n }\n\n // If it is a `DOMError` (which is a legacy API, but still supported in some browsers) then we just extract the name\n // and message, as it doesn't provide anything else. According to the spec, all `DOMExceptions` should also be\n // `Error`s, but that's not the case in IE11, so in that case we treat it the same as we do a `DOMError`.\n //\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMError\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMException\n // https://webidl.spec.whatwg.org/#es-DOMException-specialness\n if (isDOMError(exception) || isDOMException(exception )) {\n const domException = exception ;\n\n if ('stack' in (exception )) {\n event = eventFromError(stackParser, exception );\n } else {\n const name = domException.name || (isDOMError(domException) ? 'DOMError' : 'DOMException');\n const message = domException.message ? `${name}: ${domException.message}` : name;\n event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n addExceptionTypeValue(event, message);\n }\n if ('code' in domException) {\n // eslint-disable-next-line deprecation/deprecation\n event.tags = { ...event.tags, 'DOMException.code': `${domException.code}` };\n }\n\n return event;\n }\n if (isError(exception)) {\n // we have a real Error object, do nothing\n return eventFromError(stackParser, exception);\n }\n if (isPlainObject(exception) || isEvent(exception)) {\n // If it's a plain object or an instance of `Event` (the built-in JS kind, not this SDK's `Event` type), serialize\n // it manually. This will allow us to group events based on top-level keys which is much better than creating a new\n // group on any key/value change.\n const objectException = exception;\n event = eventFromPlainObject(stackParser, objectException, syntheticException, isUnhandledRejection);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n return event;\n }\n\n // If none of previous checks were valid, then it means that it's not:\n // - an instance of DOMError\n // - an instance of DOMException\n // - an instance of Event\n // - an instance of Error\n // - a valid ErrorEvent (one with an error property)\n // - a plain Object\n //\n // So bail out and capture it as a simple message:\n event = eventFromString(stackParser, exception , syntheticException, attachStacktrace);\n addExceptionTypeValue(event, `${exception}`, undefined);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n\n return event;\n}\n\nfunction eventFromString(\n stackParser,\n message,\n syntheticException,\n attachStacktrace,\n) {\n const event = {};\n\n if (attachStacktrace && syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n event.exception = {\n values: [{ value: message, stacktrace: { frames } }],\n };\n }\n addExceptionMechanism(event, { synthetic: true });\n }\n\n if (isParameterizedString(message)) {\n const { __sentry_template_string__, __sentry_template_values__ } = message;\n\n event.logentry = {\n message: __sentry_template_string__,\n params: __sentry_template_values__,\n };\n return event;\n }\n\n event.message = message;\n return event;\n}\n\nfunction getNonErrorObjectExceptionValue(\n exception,\n { isUnhandledRejection },\n) {\n const keys = extractExceptionKeysForMessage(exception);\n const captureType = isUnhandledRejection ? 'promise rejection' : 'exception';\n\n // Some ErrorEvent instances do not have an `error` property, which is why they are not handled before\n // We still want to try to get a decent message for these cases\n if (isErrorEvent(exception)) {\n return `Event \\`ErrorEvent\\` captured as ${captureType} with message \\`${exception.message}\\``;\n }\n\n if (isEvent(exception)) {\n const className = getObjectClassName(exception);\n return `Event \\`${className}\\` (type=${exception.type}) captured as ${captureType}`;\n }\n\n return `Object captured as ${captureType} with keys: ${keys}`;\n}\n\nfunction getObjectClassName(obj) {\n try {\n const prototype = Object.getPrototypeOf(obj);\n return prototype ? prototype.constructor.name : undefined;\n } catch {\n // ignore errors here\n }\n}\n\n/** If a plain object has a property that is an `Error`, return this error. */\nfunction getErrorPropertyFromObject(obj) {\n for (const prop in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, prop)) {\n const value = obj[prop];\n if (value instanceof Error) {\n return value;\n }\n }\n }\n\n return undefined;\n}\n\nexport { eventFromException, eventFromMessage, eventFromUnknownInput, exceptionFromError, extractMessage, extractType };\n//# sourceMappingURL=eventbuilder.js.map\n","import { Client, getSDKSource, applySdkMetadata, _INTERNAL_flushLogsBuffer, _INTERNAL_flushMetricsBuffer, addAutoIpAddressToSession } from '@sentry/core';\nimport { eventFromException, eventFromMessage } from './eventbuilder.js';\nimport { WINDOW } from './helpers.js';\n\n/**\n * A magic string that build tooling can leverage in order to inject a release value into the SDK.\n */\n\n/**\n * The Sentry Browser SDK Client.\n *\n * @see BrowserOptions for documentation on configuration options.\n * @see SentryClient for usage documentation.\n */\nclass BrowserClient extends Client {\n /**\n * Creates a new Browser SDK instance.\n *\n * @param options Configuration options for this SDK.\n */\n constructor(options) {\n const opts = applyDefaultOptions(options);\n const sdkSource = WINDOW.SENTRY_SDK_SOURCE || getSDKSource();\n applySdkMetadata(opts, 'browser', ['browser'], sdkSource);\n\n // Only allow IP inferral by Relay if sendDefaultPii is true\n if (opts._metadata?.sdk) {\n opts._metadata.sdk.settings = {\n infer_ip: opts.sendDefaultPii ? 'auto' : 'never',\n // purposefully allowing already passed settings to override the default\n ...opts._metadata.sdk.settings,\n };\n }\n\n super(opts);\n\n const { sendDefaultPii, sendClientReports, enableLogs, _experiments } = this._options;\n\n // Flush logs and metrics when page becomes hidden (e.g., tab switch, navigation)\n if (WINDOW.document && (sendClientReports || enableLogs || _experiments?.enableMetrics)) {\n WINDOW.document.addEventListener('visibilitychange', () => {\n if (WINDOW.document.visibilityState === 'hidden') {\n if (sendClientReports) {\n this._flushOutcomes();\n }\n if (enableLogs) {\n _INTERNAL_flushLogsBuffer(this);\n }\n if (_experiments?.enableMetrics) {\n _INTERNAL_flushMetricsBuffer(this);\n }\n }\n });\n }\n\n if (sendDefaultPii) {\n this.on('beforeSendSession', addAutoIpAddressToSession);\n }\n }\n\n /**\n * @inheritDoc\n */\n eventFromException(exception, hint) {\n return eventFromException(this._options.stackParser, exception, hint, this._options.attachStacktrace);\n }\n\n /**\n * @inheritDoc\n */\n eventFromMessage(\n message,\n level = 'info',\n hint,\n ) {\n return eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace);\n }\n\n /**\n * @inheritDoc\n */\n _prepareEvent(\n event,\n hint,\n currentScope,\n isolationScope,\n ) {\n event.platform = event.platform || 'javascript';\n\n return super._prepareEvent(event, hint, currentScope, isolationScope);\n }\n}\n\n/** Exported only for tests. */\nfunction applyDefaultOptions(optionsArg) {\n return {\n release:\n typeof __SENTRY_RELEASE__ === 'string' // This allows build tooling to find-and-replace __SENTRY_RELEASE__ to inject a release value\n ? __SENTRY_RELEASE__\n : WINDOW.SENTRY_RELEASE?.id, // This supports the variable that sentry-webpack-plugin injects\n sendClientReports: true,\n // We default this to true, as it is the safer scenario\n parentSpanIsAlwaysRootSpan: true,\n ...optionsArg,\n };\n}\n\nexport { BrowserClient, applyDefaultOptions };\n//# sourceMappingURL=client.js.map\n","/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nconst DEBUG_BUILD = (typeof __SENTRY_DEBUG__ === 'undefined' || __SENTRY_DEBUG__);\n\nexport { DEBUG_BUILD };\n//# sourceMappingURL=debug-build.js.map\n","/** Internal global with common properties and Sentry extensions */\n\n/** Get's the global object for the current JavaScript runtime */\nconst GLOBAL_OBJ = globalThis ;\n\nexport { GLOBAL_OBJ };\n//# sourceMappingURL=worldwide.js.map\n","// This is a magic string replaced by rollup\n\nconst SDK_VERSION = \"10.22.0\" ;\n\nexport { SDK_VERSION };\n//# sourceMappingURL=version.js.map\n","import { SDK_VERSION } from './utils/version.js';\nimport { GLOBAL_OBJ } from './utils/worldwide.js';\n\n/**\n * An object that contains globally accessible properties and maintains a scope stack.\n * @hidden\n */\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nfunction getMainCarrier() {\n // This ensures a Sentry carrier exists\n getSentryCarrier(GLOBAL_OBJ);\n return GLOBAL_OBJ;\n}\n\n/** Will either get the existing sentry carrier, or create a new one. */\nfunction getSentryCarrier(carrier) {\n const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n\n // For now: First SDK that sets the .version property wins\n __SENTRY__.version = __SENTRY__.version || SDK_VERSION;\n\n // Intentionally populating and returning the version of \"this\" SDK instance\n // rather than what's set in .version so that \"this\" SDK always gets its carrier\n return (__SENTRY__[SDK_VERSION] = __SENTRY__[SDK_VERSION] || {});\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__[]` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nfunction getGlobalSingleton(\n name,\n creator,\n obj = GLOBAL_OBJ,\n) {\n const __SENTRY__ = (obj.__SENTRY__ = obj.__SENTRY__ || {});\n const carrier = (__SENTRY__[SDK_VERSION] = __SENTRY__[SDK_VERSION] || {});\n // Note: We do not want to set `carrier.version` here, as this may be called before any `init` is called, e.g. for the default scopes\n return carrier[name] || (carrier[name] = creator());\n}\n\nexport { getGlobalSingleton, getMainCarrier, getSentryCarrier };\n//# sourceMappingURL=carrier.js.map\n","import { getGlobalSingleton } from '../carrier.js';\nimport { DEBUG_BUILD } from '../debug-build.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nconst CONSOLE_LEVELS = [\n 'debug',\n 'info',\n 'warn',\n 'error',\n 'log',\n 'assert',\n 'trace',\n] ;\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\n/** This may be mutated by the console instrumentation. */\nconst originalConsoleMethods\n\n = {};\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nfunction consoleSandbox(callback) {\n if (!('console' in GLOBAL_OBJ)) {\n return callback();\n }\n\n const console = GLOBAL_OBJ.console;\n const wrappedFuncs = {};\n\n const wrappedLevels = Object.keys(originalConsoleMethods) ;\n\n // Restore all wrapped console methods\n wrappedLevels.forEach(level => {\n const originalConsoleMethod = originalConsoleMethods[level];\n wrappedFuncs[level] = console[level] ;\n console[level] = originalConsoleMethod ;\n });\n\n try {\n return callback();\n } finally {\n // Revert restoration to wrapped state\n wrappedLevels.forEach(level => {\n console[level] = wrappedFuncs[level] ;\n });\n }\n}\n\nfunction enable() {\n _getLoggerSettings().enabled = true;\n}\n\nfunction disable() {\n _getLoggerSettings().enabled = false;\n}\n\nfunction isEnabled() {\n return _getLoggerSettings().enabled;\n}\n\nfunction log(...args) {\n _maybeLog('log', ...args);\n}\n\nfunction warn(...args) {\n _maybeLog('warn', ...args);\n}\n\nfunction error(...args) {\n _maybeLog('error', ...args);\n}\n\nfunction _maybeLog(level, ...args) {\n if (!DEBUG_BUILD) {\n return;\n }\n\n if (isEnabled()) {\n consoleSandbox(() => {\n GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args);\n });\n }\n}\n\nfunction _getLoggerSettings() {\n if (!DEBUG_BUILD) {\n return { enabled: false };\n }\n\n return getGlobalSingleton('loggerSettings', () => ({ enabled: false }));\n}\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n */\nconst debug = {\n /** Enable logging. */\n enable,\n /** Disable logging. */\n disable,\n /** Check if logging is enabled. */\n isEnabled,\n /** Log a message. */\n log,\n /** Log a warning. */\n warn,\n /** Log an error. */\n error,\n} ;\n\nexport { CONSOLE_LEVELS, consoleSandbox, debug, originalConsoleMethods };\n//# sourceMappingURL=debug-logger.js.map\n","const STACKTRACE_FRAME_LIMIT = 50;\nconst UNKNOWN_FUNCTION = '?';\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nfunction createStackParser(...parsers) {\n const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n return (stack, skipFirstLines = 0, framesToPop = 0) => {\n const frames = [];\n const lines = stack.split('\\n');\n\n for (let i = skipFirstLines; i < lines.length; i++) {\n let line = lines[i] ;\n // Truncate lines over 1kb because many of the regular expressions use\n // backtracking which results in run time that increases exponentially\n // with input size. Huge strings can result in hangs/Denial of Service:\n // https://github.com/getsentry/sentry-javascript/issues/2286\n if (line.length > 1024) {\n line = line.slice(0, 1024);\n }\n\n // https://github.com/getsentry/sentry-javascript/issues/5459\n // Remove webpack (error: *) wrappers\n const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n // https://github.com/getsentry/sentry-javascript/issues/7813\n // Skip Error: lines\n if (cleanedLine.match(/\\S*Error: /)) {\n continue;\n }\n\n for (const parser of sortedParsers) {\n const frame = parser(cleanedLine);\n\n if (frame) {\n frames.push(frame);\n break;\n }\n }\n\n if (frames.length >= STACKTRACE_FRAME_LIMIT + framesToPop) {\n break;\n }\n }\n\n return stripSentryFramesAndReverse(frames.slice(framesToPop));\n };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nfunction stackParserFromStackParserOptions(stackParser) {\n if (Array.isArray(stackParser)) {\n return createStackParser(...stackParser);\n }\n return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nfunction stripSentryFramesAndReverse(stack) {\n if (!stack.length) {\n return [];\n }\n\n const localStack = Array.from(stack);\n\n // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n if (/sentryWrapped/.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n }\n\n // Reversing in the middle of the procedure allows us to just pop the values off the stack\n localStack.reverse();\n\n // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n\n // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n // is produced within the scope itself, making it:\n //\n // Sentry.captureException()\n // scope.captureException()\n //\n // instead of just the top `Sentry` call itself.\n // This forces us to possibly strip an additional frame in the exact same was as above.\n if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n }\n }\n\n return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n ...frame,\n filename: frame.filename || getLastStackFrame(localStack).filename,\n function: frame.function || UNKNOWN_FUNCTION,\n }));\n}\n\nfunction getLastStackFrame(arr) {\n return arr[arr.length - 1] || {};\n}\n\nconst defaultFunctionName = '';\n\n/**\n * Safely extract function name from itself\n */\nfunction getFunctionName(fn) {\n try {\n if (!fn || typeof fn !== 'function') {\n return defaultFunctionName;\n }\n return fn.name || defaultFunctionName;\n } catch {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n return defaultFunctionName;\n }\n}\n\n/**\n * Get's stack frames from an event without needing to check for undefined properties.\n */\nfunction getFramesFromEvent(event) {\n const exception = event.exception;\n\n if (exception) {\n const frames = [];\n try {\n // @ts-expect-error Object could be undefined\n exception.values.forEach(value => {\n // @ts-expect-error Value could be undefined\n if (value.stacktrace.frames) {\n // @ts-expect-error Value could be undefined\n frames.push(...value.stacktrace.frames);\n }\n });\n return frames;\n } catch {\n return undefined;\n }\n }\n return undefined;\n}\n\nexport { UNKNOWN_FUNCTION, createStackParser, getFramesFromEvent, getFunctionName, stackParserFromStackParserOptions, stripSentryFramesAndReverse };\n//# sourceMappingURL=stacktrace.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { debug } from '../utils/debug-logger.js';\nimport { getFunctionName } from '../utils/stacktrace.js';\n\n// We keep the handlers globally\nconst handlers = {};\nconst instrumented = {};\n\n/** Add a handler function. */\nfunction addHandler(type, handler) {\n handlers[type] = handlers[type] || [];\n handlers[type].push(handler);\n}\n\n/**\n * Reset all instrumentation handlers.\n * This can be used by tests to ensure we have a clean slate of instrumentation handlers.\n */\nfunction resetInstrumentationHandlers() {\n Object.keys(handlers).forEach(key => {\n handlers[key ] = undefined;\n });\n}\n\n/** Maybe run an instrumentation function, unless it was already called. */\nfunction maybeInstrument(type, instrumentFn) {\n if (!instrumented[type]) {\n instrumented[type] = true;\n try {\n instrumentFn();\n } catch (e) {\n DEBUG_BUILD && debug.error(`Error while instrumenting ${type}`, e);\n }\n }\n}\n\n/** Trigger handlers for a given instrumentation type. */\nfunction triggerHandlers(type, data) {\n const typeHandlers = type && handlers[type];\n if (!typeHandlers) {\n return;\n }\n\n for (const handler of typeHandlers) {\n try {\n handler(data);\n } catch (e) {\n DEBUG_BUILD &&\n debug.error(\n `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n e,\n );\n }\n }\n}\n\nexport { addHandler, maybeInstrument, resetInstrumentationHandlers, triggerHandlers };\n//# sourceMappingURL=handlers.js.map\n","// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isError(wat) {\n switch (objectToString.call(wat)) {\n case '[object Error]':\n case '[object Exception]':\n case '[object DOMException]':\n case '[object WebAssembly.Exception]':\n return true;\n default:\n return isInstanceOf(wat, Error);\n }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat, className) {\n return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isErrorEvent(wat) {\n return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMError(wat) {\n return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMException(wat) {\n return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isString(wat) {\n return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given string is parameterized\n * {@link isParameterizedString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isParameterizedString(wat) {\n return (\n typeof wat === 'object' &&\n wat !== null &&\n '__sentry_template_string__' in wat &&\n '__sentry_template_values__' in wat\n );\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPrimitive(wat) {\n return wat === null || isParameterizedString(wat) || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal, or a class instance.\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPlainObject(wat) {\n return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isEvent(wat) {\n return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isElement(wat) {\n return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isRegExp(wat) {\n return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nfunction isThenable(wat) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return Boolean(wat?.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isSyntheticEvent(wat) {\n return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nfunction isInstanceOf(wat, base) {\n try {\n return wat instanceof base;\n } catch {\n return false;\n }\n}\n\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isVueViewModel(wat) {\n // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n return !!(typeof wat === 'object' && wat !== null && ((wat ).__isVue || (wat )._isVue));\n}\n\n/**\n * Checks whether the given parameter is a Standard Web API Request instance.\n *\n * Returns false if Request is not available in the current runtime.\n */\nfunction isRequest(request) {\n return typeof Request !== 'undefined' && isInstanceOf(request, Request);\n}\n\nexport { isDOMError, isDOMException, isElement, isError, isErrorEvent, isEvent, isInstanceOf, isParameterizedString, isPlainObject, isPrimitive, isRegExp, isRequest, isString, isSyntheticEvent, isThenable, isVueViewModel };\n//# sourceMappingURL=is.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { htmlTreeAsString } from './browser.js';\nimport { debug } from './debug-logger.js';\nimport { isError, isEvent, isInstanceOf, isPrimitive, isElement } from './is.js';\nimport { truncate } from './string.js';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * If the method on the passed object is not a function, the wrapper will not be applied.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, )` or `origMethod.apply(this, [])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nfunction fill(source, name, replacementFactory) {\n if (!(name in source)) {\n return;\n }\n\n // explicitly casting to unknown because we don't know the type of the method initially at all\n const original = source[name] ;\n\n if (typeof original !== 'function') {\n return;\n }\n\n const wrapped = replacementFactory(original) ;\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (typeof wrapped === 'function') {\n markFunctionWrapped(wrapped, original);\n }\n\n try {\n source[name] = wrapped;\n } catch {\n DEBUG_BUILD && debug.log(`Failed to replace method \"${name}\" in object`, source);\n }\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nfunction addNonEnumerableProperty(obj, name, value) {\n try {\n Object.defineProperty(obj, name, {\n // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n value: value,\n writable: true,\n configurable: true,\n });\n } catch {\n DEBUG_BUILD && debug.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nfunction markFunctionWrapped(wrapped, original) {\n try {\n const proto = original.prototype || {};\n wrapped.prototype = original.prototype = proto;\n addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n } catch {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available. See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction getOriginalFunction(func) {\n return func.__sentry_original__;\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor\n * an Error.\n */\nfunction convertToPlainObject(value)\n\n {\n if (isError(value)) {\n return {\n message: value.message,\n name: value.name,\n stack: value.stack,\n ...getOwnProperties(value),\n };\n } else if (isEvent(value)) {\n const newObj\n\n = {\n type: value.type,\n target: serializeEventTarget(value.target),\n currentTarget: serializeEventTarget(value.currentTarget),\n ...getOwnProperties(value),\n };\n\n if (typeof CustomEvent !== 'undefined' && isInstanceOf(value, CustomEvent)) {\n newObj.detail = value.detail;\n }\n\n return newObj;\n } else {\n return value;\n }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target) {\n try {\n return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target);\n } catch {\n return '';\n }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj) {\n if (typeof obj === 'object' && obj !== null) {\n const extractedProps = {};\n for (const property in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, property)) {\n extractedProps[property] = (obj )[property];\n }\n }\n return extractedProps;\n } else {\n return {};\n }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nfunction extractExceptionKeysForMessage(exception, maxLength = 40) {\n const keys = Object.keys(convertToPlainObject(exception));\n keys.sort();\n\n const firstKey = keys[0];\n\n if (!firstKey) {\n return '[object has no keys]';\n }\n\n if (firstKey.length >= maxLength) {\n return truncate(firstKey, maxLength);\n }\n\n for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n const serialized = keys.slice(0, includedKeys).join(', ');\n if (serialized.length > maxLength) {\n continue;\n }\n if (includedKeys === keys.length) {\n return serialized;\n }\n return truncate(serialized, maxLength);\n }\n\n return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n *\n * @deprecated This function is no longer used by the SDK and will be removed in a future major version.\n */\nfunction dropUndefinedKeys(inputValue) {\n // This map keeps track of what already visited nodes map to.\n // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n // references as the input object.\n const memoizationMap = new Map();\n\n // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys(inputValue, memoizationMap) {\n // Early return for primitive values\n if (inputValue === null || typeof inputValue !== 'object') {\n return inputValue;\n }\n\n // Check memo map first for all object types\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal ;\n }\n\n // handle arrays\n if (Array.isArray(inputValue)) {\n const returnValue = [];\n // Store mapping to handle circular references\n memoizationMap.set(inputValue, returnValue);\n\n inputValue.forEach(value => {\n returnValue.push(_dropUndefinedKeys(value, memoizationMap));\n });\n\n return returnValue ;\n }\n\n if (isPojo(inputValue)) {\n const returnValue = {};\n // Store mapping to handle circular references\n memoizationMap.set(inputValue, returnValue);\n\n const keys = Object.keys(inputValue);\n\n keys.forEach(key => {\n const val = inputValue[key];\n if (val !== undefined) {\n returnValue[key] = _dropUndefinedKeys(val, memoizationMap);\n }\n });\n\n return returnValue ;\n }\n\n // For other object types, return as is\n return inputValue;\n}\n\nfunction isPojo(input) {\n // Plain objects have Object as constructor or no constructor\n const constructor = (input ).constructor;\n return constructor === Object || constructor === undefined;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nfunction objectify(wat) {\n let objectified;\n switch (true) {\n // this will catch both undefined and null\n case wat == undefined:\n objectified = new String(wat);\n break;\n\n // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n // an object in order to wrap it.\n case typeof wat === 'symbol' || typeof wat === 'bigint':\n objectified = Object(wat);\n break;\n\n // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n case isPrimitive(wat):\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n objectified = new (wat ).constructor(wat);\n break;\n\n // by process of elimination, at this point we know that `wat` must already be an object\n default:\n objectified = wat;\n break;\n }\n return objectified;\n}\n\nexport { addNonEnumerableProperty, convertToPlainObject, dropUndefinedKeys, extractExceptionKeysForMessage, fill, getOriginalFunction, markFunctionWrapped, objectify };\n//# sourceMappingURL=object.js.map\n","import { addNonEnumerableProperty } from './object.js';\nimport { snipLine } from './string.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nfunction getCrypto() {\n const gbl = GLOBAL_OBJ ;\n return gbl.crypto || gbl.msCrypto;\n}\n\nlet emptyUuid;\n\nfunction getRandomByte() {\n return Math.random() * 16;\n}\n\n/**\n * UUID4 generator\n * @param crypto Object that provides the crypto API.\n * @returns string Generated UUID4.\n */\nfunction uuid4(crypto = getCrypto()) {\n try {\n if (crypto?.randomUUID) {\n return crypto.randomUUID().replace(/-/g, '');\n }\n } catch {\n // some runtimes can crash invoking crypto\n // https://github.com/getsentry/sentry-javascript/issues/8935\n }\n\n if (!emptyUuid) {\n // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n emptyUuid = ([1e7] ) + 1e3 + 4e3 + 8e3 + 1e11;\n }\n\n return emptyUuid.replace(/[018]/g, c =>\n // eslint-disable-next-line no-bitwise\n ((c ) ^ ((getRandomByte() & 15) >> ((c ) / 4))).toString(16),\n );\n}\n\nfunction getFirstException(event) {\n return event.exception?.values?.[0];\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nfunction getEventDescription(event) {\n const { message, event_id: eventId } = event;\n if (message) {\n return message;\n }\n\n const firstException = getFirstException(event);\n if (firstException) {\n if (firstException.type && firstException.value) {\n return `${firstException.type}: ${firstException.value}`;\n }\n return firstException.type || firstException.value || eventId || '';\n }\n return eventId || '';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nfunction addExceptionTypeValue(event, value, type) {\n const exception = (event.exception = event.exception || {});\n const values = (exception.values = exception.values || []);\n const firstException = (values[0] = values[0] || {});\n if (!firstException.value) {\n firstException.value = value || '';\n }\n if (!firstException.type) {\n firstException.type = type || 'Error';\n }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nfunction addExceptionMechanism(event, newMechanism) {\n const firstException = getFirstException(event);\n if (!firstException) {\n return;\n }\n\n const defaultMechanism = { type: 'generic', handled: true };\n const currentMechanism = firstException.mechanism;\n firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n if (newMechanism && 'data' in newMechanism) {\n const mergedData = { ...currentMechanism?.data, ...newMechanism.data };\n firstException.mechanism.data = mergedData;\n }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\n\nfunction _parseInt(input) {\n return parseInt(input || '', 10);\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nfunction parseSemver(input) {\n const match = input.match(SEMVER_REGEXP) || [];\n const major = _parseInt(match[1]);\n const minor = _parseInt(match[2]);\n const patch = _parseInt(match[3]);\n return {\n buildmetadata: match[5],\n major: isNaN(major) ? undefined : major,\n minor: isNaN(minor) ? undefined : minor,\n patch: isNaN(patch) ? undefined : patch,\n prerelease: match[4],\n };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nfunction addContextToFrame(lines, frame, linesOfContext = 5) {\n // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n if (frame.lineno === undefined) {\n return;\n }\n\n const maxLines = lines.length;\n const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n frame.pre_context = lines\n .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n .map((line) => snipLine(line, 0));\n\n // We guard here to ensure this is not larger than the existing number of lines\n const lineIndex = Math.min(maxLines - 1, sourceLine);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n frame.context_line = snipLine(lines[lineIndex], frame.colno || 0);\n\n frame.post_context = lines\n .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n .map((line) => snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nfunction checkOrSetAlreadyCaught(exception) {\n if (isAlreadyCaptured(exception)) {\n return true;\n }\n\n try {\n // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n // `ExtraErrorData` integration\n addNonEnumerableProperty(exception , '__sentry_captured__', true);\n } catch {\n // `exception` is a primitive, so we can't mark it seen\n }\n\n return false;\n}\n\nfunction isAlreadyCaptured(exception) {\n try {\n return (exception ).__sentry_captured__;\n } catch {} // eslint-disable-line no-empty\n}\n\nexport { addContextToFrame, addExceptionMechanism, addExceptionTypeValue, checkOrSetAlreadyCaught, getEventDescription, parseSemver, uuid4 };\n//# sourceMappingURL=misc.js.map\n","import { GLOBAL_OBJ } from './worldwide.js';\n\nconst ONE_SECOND_IN_MS = 1000;\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nfunction dateTimestampInSeconds() {\n return Date.now() / ONE_SECOND_IN_MS;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction createUnixTimestampInSecondsFunc() {\n const { performance } = GLOBAL_OBJ ;\n // Some browser and environments don't have a performance or timeOrigin, so we fallback to\n // using Date.now() to compute the starting time.\n if (!performance?.now || !performance.timeOrigin) {\n return dateTimestampInSeconds;\n }\n\n const timeOrigin = performance.timeOrigin;\n\n // performance.now() is a monotonic clock, which means it starts at 0 when the process begins. To get the current\n // wall clock time (actual UNIX timestamp), we need to add the starting time origin and the current time elapsed.\n //\n // TODO: This does not account for the case where the monotonic clock that powers performance.now() drifts from the\n // wall clock time, which causes the returned timestamp to be inaccurate. We should investigate how to detect and\n // correct for this.\n // See: https://github.com/getsentry/sentry-javascript/issues/2590\n // See: https://github.com/mdn/content/issues/4713\n // See: https://dev.to/noamr/when-a-millisecond-is-not-a-millisecond-3h6\n return () => {\n return (timeOrigin + performance.now()) / ONE_SECOND_IN_MS;\n };\n}\n\nlet _cachedTimestampInSeconds;\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nfunction timestampInSeconds() {\n // We store this in a closure so that we don't have to create a new function every time this is called.\n const func = _cachedTimestampInSeconds ?? (_cachedTimestampInSeconds = createUnixTimestampInSecondsFunc());\n return func();\n}\n\n/**\n * Cached result of getBrowserTimeOrigin.\n */\nlet cachedTimeOrigin;\n\n/**\n * Gets the time origin and the mode used to determine it.\n */\nfunction getBrowserTimeOrigin() {\n // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n // data as reliable if they are within a reasonable threshold of the current time.\n\n const { performance } = GLOBAL_OBJ ;\n if (!performance?.now) {\n return [undefined, 'none'];\n }\n\n const threshold = 3600 * 1000;\n const performanceNow = performance.now();\n const dateNow = Date.now();\n\n // if timeOrigin isn't available set delta to threshold so it isn't used\n const timeOriginDelta = performance.timeOrigin\n ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n : threshold;\n const timeOriginIsReliable = timeOriginDelta < threshold;\n\n // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n // Date API.\n // eslint-disable-next-line deprecation/deprecation\n const navigationStart = performance.timing?.navigationStart;\n const hasNavigationStart = typeof navigationStart === 'number';\n // if navigationStart isn't available set delta to threshold so it isn't used\n const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n const navigationStartIsReliable = navigationStartDelta < threshold;\n\n if (timeOriginIsReliable || navigationStartIsReliable) {\n // Use the more reliable time origin\n if (timeOriginDelta <= navigationStartDelta) {\n return [performance.timeOrigin, 'timeOrigin'];\n } else {\n return [navigationStart, 'navigationStart'];\n }\n }\n\n // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n return [dateNow, 'dateNow'];\n}\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nfunction browserPerformanceTimeOrigin() {\n if (!cachedTimeOrigin) {\n cachedTimeOrigin = getBrowserTimeOrigin();\n }\n\n return cachedTimeOrigin[0];\n}\n\nexport { browserPerformanceTimeOrigin, dateTimestampInSeconds, timestampInSeconds };\n//# sourceMappingURL=time.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { debug } from './debug-logger.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nconst WINDOW = GLOBAL_OBJ ;\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsErrorEvent() {\n try {\n new ErrorEvent('');\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMError() {\n try {\n // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n // 1 argument required, but only 0 present.\n // @ts-expect-error It really needs 1 argument, not 0.\n new DOMError('');\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMException() {\n try {\n new DOMException('');\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsHistory() {\n return 'history' in WINDOW && !!WINDOW.history;\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nconst supportsFetch = _isFetchSupported;\n\nfunction _isFetchSupported() {\n if (!('fetch' in WINDOW)) {\n return false;\n }\n\n try {\n new Headers();\n new Request('http://www.example.com');\n new Response();\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * isNative checks if the given function is a native implementation\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction isNativeFunction(func) {\n return func && /^function\\s+\\w+\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nfunction supportsNativeFetch() {\n if (typeof EdgeRuntime === 'string') {\n return true;\n }\n\n if (!_isFetchSupported()) {\n return false;\n }\n\n // Fast path to avoid DOM I/O\n // eslint-disable-next-line @typescript-eslint/unbound-method\n if (isNativeFunction(WINDOW.fetch)) {\n return true;\n }\n\n // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n // so create a \"pure\" iframe to see if that has native fetch\n let result = false;\n const doc = WINDOW.document;\n // eslint-disable-next-line deprecation/deprecation\n if (doc && typeof (doc.createElement ) === 'function') {\n try {\n const sandbox = doc.createElement('iframe');\n sandbox.hidden = true;\n doc.head.appendChild(sandbox);\n if (sandbox.contentWindow?.fetch) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n result = isNativeFunction(sandbox.contentWindow.fetch);\n }\n doc.head.removeChild(sandbox);\n } catch (err) {\n DEBUG_BUILD && debug.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n }\n }\n\n return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsReportingObserver() {\n return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nfunction supportsReferrerPolicy() {\n // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n // (see https://caniuse.com/#feat=referrer-policy),\n // it doesn't. And it throws an exception instead of ignoring this parameter...\n // REF: https://github.com/getsentry/raven-js/issues/1233\n\n if (!_isFetchSupported()) {\n return false;\n }\n\n try {\n new Request('_', {\n referrerPolicy: 'origin' ,\n });\n return true;\n } catch {\n return false;\n }\n}\n\nexport { isNativeFunction, supportsDOMError, supportsDOMException, supportsErrorEvent, supportsFetch, supportsHistory, supportsNativeFetch, supportsReferrerPolicy, supportsReportingObserver };\n//# sourceMappingURL=supports.js.map\n","import { GLOBAL_OBJ } from '@sentry/core';\n\nconst WINDOW = GLOBAL_OBJ\n\n;\n\nexport { WINDOW };\n//# sourceMappingURL=types.js.map\n","import { addHandler, maybeInstrument, triggerHandlers, fill, addNonEnumerableProperty, uuid4 } from '@sentry/core';\nimport { WINDOW } from '../types.js';\n\nconst DEBOUNCE_DURATION = 1000;\n\nlet debounceTimerID;\nlet lastCapturedEventType;\nlet lastCapturedEventTargetId;\n\n/**\n * Add an instrumentation handler for when a click or a keypress happens.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addClickKeypressInstrumentationHandler(handler) {\n const type = 'dom';\n addHandler(type, handler);\n maybeInstrument(type, instrumentDOM);\n}\n\n/** Exported for tests only. */\nfunction instrumentDOM() {\n if (!WINDOW.document) {\n return;\n }\n\n // Make it so that any click or keypress that is unhandled / bubbled up all the way to the document triggers our dom\n // handlers. (Normally we have only one, which captures a breadcrumb for each click or keypress.) Do this before\n // we instrument `addEventListener` so that we don't end up attaching this handler twice.\n const triggerDOMHandler = triggerHandlers.bind(null, 'dom');\n const globalDOMEventHandler = makeDOMEventHandler(triggerDOMHandler, true);\n WINDOW.document.addEventListener('click', globalDOMEventHandler, false);\n WINDOW.document.addEventListener('keypress', globalDOMEventHandler, false);\n\n // After hooking into click and keypress events bubbled up to `document`, we also hook into user-handled\n // clicks & keypresses, by adding an event listener of our own to any element to which they add a listener. That\n // way, whenever one of their handlers is triggered, ours will be, too. (This is needed because their handler\n // could potentially prevent the event from bubbling up to our global listeners. This way, our handler are still\n // guaranteed to fire at least once.)\n ['EventTarget', 'Node'].forEach((target) => {\n const globalObject = WINDOW ;\n const proto = globalObject[target]?.prototype;\n\n // eslint-disable-next-line no-prototype-builtins\n if (!proto?.hasOwnProperty?.('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (originalAddEventListener) {\n return function ( type, listener, options) {\n if (type === 'click' || type == 'keypress') {\n try {\n const handlers = (this.__sentry_instrumentation_handlers__ =\n this.__sentry_instrumentation_handlers__ || {});\n const handlerForType = (handlers[type] = handlers[type] || { refCount: 0 });\n\n if (!handlerForType.handler) {\n const handler = makeDOMEventHandler(triggerDOMHandler);\n handlerForType.handler = handler;\n originalAddEventListener.call(this, type, handler, options);\n }\n\n handlerForType.refCount++;\n } catch {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListeners` calls with no proper `this` context.\n }\n }\n\n return originalAddEventListener.call(this, type, listener, options);\n };\n });\n\n fill(\n proto,\n 'removeEventListener',\n function (originalRemoveEventListener) {\n return function ( type, listener, options) {\n if (type === 'click' || type == 'keypress') {\n try {\n const handlers = this.__sentry_instrumentation_handlers__ || {};\n const handlerForType = handlers[type];\n\n if (handlerForType) {\n handlerForType.refCount--;\n // If there are no longer any custom handlers of the current type on this element, we can remove ours, too.\n if (handlerForType.refCount <= 0) {\n originalRemoveEventListener.call(this, type, handlerForType.handler, options);\n handlerForType.handler = undefined;\n delete handlers[type]; // eslint-disable-line @typescript-eslint/no-dynamic-delete\n }\n\n // If there are no longer any custom handlers of any type on this element, cleanup everything.\n if (Object.keys(handlers).length === 0) {\n delete this.__sentry_instrumentation_handlers__;\n }\n }\n } catch {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListeners` calls with no proper `this` context.\n }\n }\n\n return originalRemoveEventListener.call(this, type, listener, options);\n };\n },\n );\n });\n}\n\n/**\n * Check whether the event is similar to the last captured one. For example, two click events on the same button.\n */\nfunction isSimilarToLastCapturedEvent(event) {\n // If both events have different type, then user definitely performed two separate actions. e.g. click + keypress.\n if (event.type !== lastCapturedEventType) {\n return false;\n }\n\n try {\n // If both events have the same type, it's still possible that actions were performed on different targets.\n // e.g. 2 clicks on different buttons.\n if (!event.target || (event.target )._sentryId !== lastCapturedEventTargetId) {\n return false;\n }\n } catch {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n }\n\n // If both events have the same type _and_ same `target` (an element which triggered an event, _not necessarily_\n // to which an event listener was attached), we treat them as the same action, as we want to capture\n // only one breadcrumb. e.g. multiple clicks on the same button, or typing inside a user input box.\n return true;\n}\n\n/**\n * Decide whether an event should be captured.\n * @param event event to be captured\n */\nfunction shouldSkipDOMEvent(eventType, target) {\n // We are only interested in filtering `keypress` events for now.\n if (eventType !== 'keypress') {\n return false;\n }\n\n if (!target?.tagName) {\n return true;\n }\n\n // Only consider keypress events on actual input elements. This will disregard keypresses targeting body\n // e.g.tabbing through elements, hotkeys, etc.\n if (target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable) {\n return false;\n }\n\n return true;\n}\n\n/**\n * Wraps addEventListener to capture UI breadcrumbs\n */\nfunction makeDOMEventHandler(\n handler,\n globalListener = false,\n) {\n return (event) => {\n // It's possible this handler might trigger multiple times for the same\n // event (e.g. event propagation through node ancestors).\n // Ignore if we've already captured that event.\n if (!event || event['_sentryCaptured']) {\n return;\n }\n\n const target = getEventTarget(event);\n\n // We always want to skip _some_ events.\n if (shouldSkipDOMEvent(event.type, target)) {\n return;\n }\n\n // Mark event as \"seen\"\n addNonEnumerableProperty(event, '_sentryCaptured', true);\n\n if (target && !target._sentryId) {\n // Add UUID to event target so we can identify if\n addNonEnumerableProperty(target, '_sentryId', uuid4());\n }\n\n const name = event.type === 'keypress' ? 'input' : event.type;\n\n // If there is no last captured event, it means that we can safely capture the new event and store it for future comparisons.\n // If there is a last captured event, see if the new event is different enough to treat it as a unique one.\n // If that's the case, emit the previous event and store locally the newly-captured DOM event.\n if (!isSimilarToLastCapturedEvent(event)) {\n const handlerData = { event, name, global: globalListener };\n handler(handlerData);\n lastCapturedEventType = event.type;\n lastCapturedEventTargetId = target ? target._sentryId : undefined;\n }\n\n // Start a new debounce timer that will prevent us from capturing multiple events that should be grouped together.\n clearTimeout(debounceTimerID);\n debounceTimerID = WINDOW.setTimeout(() => {\n lastCapturedEventTargetId = undefined;\n lastCapturedEventType = undefined;\n }, DEBOUNCE_DURATION);\n };\n}\n\nfunction getEventTarget(event) {\n try {\n return event.target ;\n } catch {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n return null;\n }\n}\n\nexport { addClickKeypressInstrumentationHandler, instrumentDOM };\n//# sourceMappingURL=dom.js.map\n","import { addHandler, maybeInstrument, triggerHandlers, supportsHistory, fill } from '@sentry/core';\nimport { WINDOW } from '../types.js';\n\nlet lastHref;\n\n/**\n * Add an instrumentation handler for when a fetch request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addHistoryInstrumentationHandler(handler) {\n const type = 'history';\n addHandler(type, handler);\n maybeInstrument(type, instrumentHistory);\n}\n\n/**\n * Exported just for testing\n */\nfunction instrumentHistory() {\n // The `popstate` event may also be triggered on `pushState`, but it may not always reliably be emitted by the browser\n // Which is why we also monkey-patch methods below, in addition to this\n WINDOW.addEventListener('popstate', () => {\n const to = WINDOW.location.href;\n // keep track of the current URL state, as we always receive only the updated state\n const from = lastHref;\n lastHref = to;\n\n if (from === to) {\n return;\n }\n\n const handlerData = { from, to } ;\n triggerHandlers('history', handlerData);\n });\n\n // Just guard against this not being available, in weird environments\n if (!supportsHistory()) {\n return;\n }\n\n function historyReplacementFunction(originalHistoryFunction) {\n return function ( ...args) {\n const url = args.length > 2 ? args[2] : undefined;\n if (url) {\n const from = lastHref;\n\n // Ensure the URL is absolute\n // this can be either a path, then it is relative to the current origin\n // or a full URL of the current origin - other origins are not allowed\n // See: https://developer.mozilla.org/en-US/docs/Web/API/History/pushState#url\n // coerce to string (this is what pushState does)\n const to = getAbsoluteUrl(String(url));\n\n // keep track of the current URL state, as we always receive only the updated state\n lastHref = to;\n\n if (from === to) {\n return originalHistoryFunction.apply(this, args);\n }\n\n const handlerData = { from, to } ;\n triggerHandlers('history', handlerData);\n }\n return originalHistoryFunction.apply(this, args);\n };\n }\n\n fill(WINDOW.history, 'pushState', historyReplacementFunction);\n fill(WINDOW.history, 'replaceState', historyReplacementFunction);\n}\n\nfunction getAbsoluteUrl(urlOrPath) {\n try {\n const url = new URL(urlOrPath, WINDOW.location.origin);\n return url.toString();\n } catch {\n // fallback, just do nothing\n return urlOrPath;\n }\n}\n\nexport { addHistoryInstrumentationHandler, instrumentHistory };\n//# sourceMappingURL=history.js.map\n","import { addHandler, maybeInstrument, timestampInSeconds, isString, triggerHandlers } from '@sentry/core';\nimport { WINDOW } from '../types.js';\n\nconst SENTRY_XHR_DATA_KEY = '__sentry_xhr_v3__';\n\n/**\n * Add an instrumentation handler for when an XHR request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addXhrInstrumentationHandler(handler) {\n const type = 'xhr';\n addHandler(type, handler);\n maybeInstrument(type, instrumentXHR);\n}\n\n/** Exported only for tests. */\nfunction instrumentXHR() {\n if (!(WINDOW ).XMLHttpRequest) {\n return;\n }\n\n const xhrproto = XMLHttpRequest.prototype;\n\n // eslint-disable-next-line @typescript-eslint/unbound-method\n xhrproto.open = new Proxy(xhrproto.open, {\n apply(\n originalOpen,\n xhrOpenThisArg,\n xhrOpenArgArray\n\n,\n ) {\n // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n // it means the error, that was caused by your XHR call did not\n // have a stack trace. If you are using HttpClient integration,\n // this is the expected behavior, as we are using this virtual error to capture\n // the location of your XHR call, and group your HttpClient events accordingly.\n const virtualError = new Error();\n\n const startTimestamp = timestampInSeconds() * 1000;\n\n // open() should always be called with two or more arguments\n // But to be on the safe side, we actually validate this and bail out if we don't have a method & url\n const method = isString(xhrOpenArgArray[0]) ? xhrOpenArgArray[0].toUpperCase() : undefined;\n const url = parseXhrUrlArg(xhrOpenArgArray[1]);\n\n if (!method || !url) {\n return originalOpen.apply(xhrOpenThisArg, xhrOpenArgArray);\n }\n\n xhrOpenThisArg[SENTRY_XHR_DATA_KEY] = {\n method,\n url,\n request_headers: {},\n };\n\n // if Sentry key appears in URL, don't capture it as a request\n if (method === 'POST' && url.match(/sentry_key/)) {\n xhrOpenThisArg.__sentry_own_request__ = true;\n }\n\n const onreadystatechangeHandler = () => {\n // For whatever reason, this is not the same instance here as from the outer method\n const xhrInfo = xhrOpenThisArg[SENTRY_XHR_DATA_KEY];\n\n if (!xhrInfo) {\n return;\n }\n\n if (xhrOpenThisArg.readyState === 4) {\n try {\n // touching statusCode in some platforms throws\n // an exception\n xhrInfo.status_code = xhrOpenThisArg.status;\n } catch {\n /* do nothing */\n }\n\n const handlerData = {\n endTimestamp: timestampInSeconds() * 1000,\n startTimestamp,\n xhr: xhrOpenThisArg,\n virtualError,\n };\n triggerHandlers('xhr', handlerData);\n }\n };\n\n if ('onreadystatechange' in xhrOpenThisArg && typeof xhrOpenThisArg.onreadystatechange === 'function') {\n xhrOpenThisArg.onreadystatechange = new Proxy(xhrOpenThisArg.onreadystatechange, {\n apply(originalOnreadystatechange, onreadystatechangeThisArg, onreadystatechangeArgArray) {\n onreadystatechangeHandler();\n return originalOnreadystatechange.apply(onreadystatechangeThisArg, onreadystatechangeArgArray);\n },\n });\n } else {\n xhrOpenThisArg.addEventListener('readystatechange', onreadystatechangeHandler);\n }\n\n // Intercepting `setRequestHeader` to access the request headers of XHR instance.\n // This will only work for user/library defined headers, not for the default/browser-assigned headers.\n // Request cookies are also unavailable for XHR, as `Cookie` header can't be defined by `setRequestHeader`.\n xhrOpenThisArg.setRequestHeader = new Proxy(xhrOpenThisArg.setRequestHeader, {\n apply(\n originalSetRequestHeader,\n setRequestHeaderThisArg,\n setRequestHeaderArgArray,\n ) {\n const [header, value] = setRequestHeaderArgArray;\n\n const xhrInfo = setRequestHeaderThisArg[SENTRY_XHR_DATA_KEY];\n\n if (xhrInfo && isString(header) && isString(value)) {\n xhrInfo.request_headers[header.toLowerCase()] = value;\n }\n\n return originalSetRequestHeader.apply(setRequestHeaderThisArg, setRequestHeaderArgArray);\n },\n });\n\n return originalOpen.apply(xhrOpenThisArg, xhrOpenArgArray);\n },\n });\n\n // eslint-disable-next-line @typescript-eslint/unbound-method\n xhrproto.send = new Proxy(xhrproto.send, {\n apply(originalSend, sendThisArg, sendArgArray) {\n const sentryXhrData = sendThisArg[SENTRY_XHR_DATA_KEY];\n\n if (!sentryXhrData) {\n return originalSend.apply(sendThisArg, sendArgArray);\n }\n\n if (sendArgArray[0] !== undefined) {\n sentryXhrData.body = sendArgArray[0];\n }\n\n const handlerData = {\n startTimestamp: timestampInSeconds() * 1000,\n xhr: sendThisArg,\n };\n triggerHandlers('xhr', handlerData);\n\n return originalSend.apply(sendThisArg, sendArgArray);\n },\n });\n}\n\n/**\n * Parses the URL argument of a XHR method to a string.\n *\n * See: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/open#url\n * url: A string or any other object with a stringifier — including a URL object — that provides the URL of the resource to send the request to.\n *\n * @param url - The URL argument of an XHR method\n * @returns The parsed URL string or undefined if the URL is invalid\n */\nfunction parseXhrUrlArg(url) {\n if (isString(url)) {\n return url;\n }\n\n try {\n // If the passed in argument is not a string, it should have a `toString` method as a stringifier.\n // If that fails, we just return undefined (like in IE11 where URL is not available)\n return (url ).toString();\n } catch {} // eslint-disable-line no-empty\n\n return undefined;\n}\n\nexport { SENTRY_XHR_DATA_KEY, addXhrInstrumentationHandler, instrumentXHR };\n//# sourceMappingURL=xhr.js.map\n","import { createStackParser, UNKNOWN_FUNCTION } from '@sentry/core';\n\nconst OPERA10_PRIORITY = 10;\nconst OPERA11_PRIORITY = 20;\nconst CHROME_PRIORITY = 30;\nconst WINJS_PRIORITY = 40;\nconst GECKO_PRIORITY = 50;\n\nfunction createFrame(filename, func, lineno, colno) {\n const frame = {\n filename,\n function: func === '' ? UNKNOWN_FUNCTION : func,\n in_app: true, // All browser frames are considered in_app\n };\n\n if (lineno !== undefined) {\n frame.lineno = lineno;\n }\n\n if (colno !== undefined) {\n frame.colno = colno;\n }\n\n return frame;\n}\n\n// This regex matches frames that have no function name (ie. are at the top level of a module).\n// For example \"at http://localhost:5000//script.js:1:126\"\n// Frames _with_ function names usually look as follows: \"at commitLayoutEffects (react-dom.development.js:23426:1)\"\nconst chromeRegexNoFnName = /^\\s*at (\\S+?)(?::(\\d+))(?::(\\d+))\\s*$/i;\n\n// This regex matches all the frames that have a function name.\nconst chromeRegex =\n /^\\s*at (?:(.+?\\)(?: \\[.+\\])?|.*?) ?\\((?:address at )?)?(?:async )?((?:|[-a-z]+:|.*bundle|\\/)?.*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\n\nconst chromeEvalRegex = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\n// Matches stack frames with data URIs instead of filename so we can still get the function name\n// Example: \"at dynamicFn (data:application/javascript,export function dynamicFn() {...\"\nconst chromeDataUriRegex = /at (.+?) ?\\(data:(.+?),/;\n\n// Chromium based browsers: Chrome, Brave, new Opera, new Edge\n// We cannot call this variable `chrome` because it can conflict with global `chrome` variable in certain environments\n// See: https://github.com/getsentry/sentry-javascript/issues/6880\nconst chromeStackParserFn = line => {\n const dataUriMatch = line.match(chromeDataUriRegex);\n if (dataUriMatch) {\n return {\n filename: ``,\n function: dataUriMatch[1],\n };\n }\n\n // If the stack line has no function name, we need to parse it differently\n const noFnParts = chromeRegexNoFnName.exec(line) ;\n\n if (noFnParts) {\n const [, filename, line, col] = noFnParts;\n return createFrame(filename, UNKNOWN_FUNCTION, +line, +col);\n }\n\n const parts = chromeRegex.exec(line) ;\n\n if (parts) {\n const isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n if (isEval) {\n const subMatch = chromeEvalRegex.exec(parts[2]) ;\n\n if (subMatch) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = subMatch[1]; // url\n parts[3] = subMatch[2]; // line\n parts[4] = subMatch[3]; // column\n }\n }\n\n // Kamil: One more hack won't hurt us right? Understanding and adding more rules on top of these regexps right now\n // would be way too time consuming. (TODO: Rewrite whole RegExp to be more readable)\n const [func, filename] = extractSafariExtensionDetails(parts[1] || UNKNOWN_FUNCTION, parts[2]);\n\n return createFrame(filename, func, parts[3] ? +parts[3] : undefined, parts[4] ? +parts[4] : undefined);\n }\n\n return;\n};\n\nconst chromeStackLineParser = [CHROME_PRIORITY, chromeStackParserFn];\n\n// gecko regex: `(?:bundle|\\d+\\.js)`: `bundle` is for react native, `\\d+\\.js` also but specifically for ram bundles because it\n// generates filenames without a prefix like `file://` the filenames in the stacktrace are just 42.js\n// We need this specific case for now because we want no other regex to match.\nconst geckoREgex =\n /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)?((?:[-a-z]+)?:\\/.*?|\\[native code\\]|[^@]*(?:bundle|\\d+\\.js)|\\/[\\w\\-. /=]+)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nconst geckoEvalRegex = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nconst gecko = line => {\n const parts = geckoREgex.exec(line) ;\n\n if (parts) {\n const isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n if (isEval) {\n const subMatch = geckoEvalRegex.exec(parts[3]) ;\n\n if (subMatch) {\n // throw out eval line/column and use top-most line number\n parts[1] = parts[1] || 'eval';\n parts[3] = subMatch[1];\n parts[4] = subMatch[2];\n parts[5] = ''; // no column when eval\n }\n }\n\n let filename = parts[3];\n let func = parts[1] || UNKNOWN_FUNCTION;\n [func, filename] = extractSafariExtensionDetails(func, filename);\n\n return createFrame(filename, func, parts[4] ? +parts[4] : undefined, parts[5] ? +parts[5] : undefined);\n }\n\n return;\n};\n\nconst geckoStackLineParser = [GECKO_PRIORITY, gecko];\n\nconst winjsRegex = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:[-a-z]+):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nconst winjs = line => {\n const parts = winjsRegex.exec(line) ;\n\n return parts\n ? createFrame(parts[2], parts[1] || UNKNOWN_FUNCTION, +parts[3], parts[4] ? +parts[4] : undefined)\n : undefined;\n};\n\nconst winjsStackLineParser = [WINJS_PRIORITY, winjs];\n\nconst opera10Regex = / line (\\d+).*script (?:in )?(\\S+)(?:: in function (\\S+))?$/i;\n\nconst opera10 = line => {\n const parts = opera10Regex.exec(line) ;\n return parts ? createFrame(parts[2], parts[3] || UNKNOWN_FUNCTION, +parts[1]) : undefined;\n};\n\nconst opera10StackLineParser = [OPERA10_PRIORITY, opera10];\n\nconst opera11Regex =\n / line (\\d+), column (\\d+)\\s*(?:in (?:]+)>|([^)]+))\\(.*\\))? in (.*):\\s*$/i;\n\nconst opera11 = line => {\n const parts = opera11Regex.exec(line) ;\n return parts ? createFrame(parts[5], parts[3] || parts[4] || UNKNOWN_FUNCTION, +parts[1], +parts[2]) : undefined;\n};\n\nconst opera11StackLineParser = [OPERA11_PRIORITY, opera11];\n\nconst defaultStackLineParsers = [chromeStackLineParser, geckoStackLineParser];\n\nconst defaultStackParser = createStackParser(...defaultStackLineParsers);\n\n/**\n * Safari web extensions, starting version unknown, can produce \"frames-only\" stacktraces.\n * What it means, is that instead of format like:\n *\n * Error: wat\n * at function@url:row:col\n * at function@url:row:col\n * at function@url:row:col\n *\n * it produces something like:\n *\n * function@url:row:col\n * function@url:row:col\n * function@url:row:col\n *\n * Because of that, it won't be captured by `chrome` RegExp and will fall into `Gecko` branch.\n * This function is extracted so that we can use it in both places without duplicating the logic.\n * Unfortunately \"just\" changing RegExp is too complicated now and making it pass all tests\n * and fix this case seems like an impossible, or at least way too time-consuming task.\n */\nconst extractSafariExtensionDetails = (func, filename) => {\n const isSafariExtension = func.indexOf('safari-extension') !== -1;\n const isSafariWebExtension = func.indexOf('safari-web-extension') !== -1;\n\n return isSafariExtension || isSafariWebExtension\n ? [\n func.indexOf('@') !== -1 ? (func.split('@')[0] ) : UNKNOWN_FUNCTION,\n isSafariExtension ? `safari-extension:${filename}` : `safari-web-extension:${filename}`,\n ]\n : [func, filename];\n};\n\nexport { chromeStackLineParser, defaultStackLineParsers, defaultStackParser, geckoStackLineParser, opera10StackLineParser, opera11StackLineParser, winjsStackLineParser };\n//# sourceMappingURL=stack-parsers.js.map\n","/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nconst DEBUG_BUILD = (typeof __SENTRY_DEBUG__ === 'undefined' || __SENTRY_DEBUG__);\n\nexport { DEBUG_BUILD };\n//# sourceMappingURL=debug-build.js.map\n","import { defineIntegration, addConsoleInstrumentationHandler, addFetchInstrumentationHandler, getClient, safeJoin, severityLevelFromString, addBreadcrumb, debug, htmlTreeAsString, getComponentName, getBreadcrumbLogLevelFromHttpStatusCode, parseUrl, getEventDescription } from '@sentry/core';\nimport { addClickKeypressInstrumentationHandler, addXhrInstrumentationHandler, addHistoryInstrumentationHandler, SENTRY_XHR_DATA_KEY } from '@sentry-internal/browser-utils';\nimport { DEBUG_BUILD } from '../debug-build.js';\nimport { WINDOW } from '../helpers.js';\n\n/** maxStringLength gets capped to prevent 100 breadcrumbs exceeding 1MB event payload size */\nconst MAX_ALLOWED_STRING_LENGTH = 1024;\n\nconst INTEGRATION_NAME = 'Breadcrumbs';\n\nconst _breadcrumbsIntegration = ((options = {}) => {\n const _options = {\n console: true,\n dom: true,\n fetch: true,\n history: true,\n sentry: true,\n xhr: true,\n ...options,\n };\n\n return {\n name: INTEGRATION_NAME,\n setup(client) {\n // TODO(v11): Remove this functionality and use `consoleIntegration` from @sentry/core instead.\n if (_options.console) {\n addConsoleInstrumentationHandler(_getConsoleBreadcrumbHandler(client));\n }\n if (_options.dom) {\n addClickKeypressInstrumentationHandler(_getDomBreadcrumbHandler(client, _options.dom));\n }\n if (_options.xhr) {\n addXhrInstrumentationHandler(_getXhrBreadcrumbHandler(client));\n }\n if (_options.fetch) {\n addFetchInstrumentationHandler(_getFetchBreadcrumbHandler(client));\n }\n if (_options.history) {\n addHistoryInstrumentationHandler(_getHistoryBreadcrumbHandler(client));\n }\n if (_options.sentry) {\n client.on('beforeSendEvent', _getSentryBreadcrumbHandler(client));\n }\n },\n };\n}) ;\n\nconst breadcrumbsIntegration = defineIntegration(_breadcrumbsIntegration);\n\n/**\n * Adds a breadcrumb for Sentry events or transactions if this option is enabled.\n */\nfunction _getSentryBreadcrumbHandler(client) {\n return function addSentryBreadcrumb(event) {\n if (getClient() !== client) {\n return;\n }\n\n addBreadcrumb(\n {\n category: `sentry.${event.type === 'transaction' ? 'transaction' : 'event'}`,\n event_id: event.event_id,\n level: event.level,\n message: getEventDescription(event),\n },\n {\n event,\n },\n );\n };\n}\n\n/**\n * A HOC that creates a function that creates breadcrumbs from DOM API calls.\n * This is a HOC so that we get access to dom options in the closure.\n */\nfunction _getDomBreadcrumbHandler(\n client,\n dom,\n) {\n return function _innerDomBreadcrumb(handlerData) {\n if (getClient() !== client) {\n return;\n }\n\n let target;\n let componentName;\n let keyAttrs = typeof dom === 'object' ? dom.serializeAttribute : undefined;\n\n let maxStringLength =\n typeof dom === 'object' && typeof dom.maxStringLength === 'number' ? dom.maxStringLength : undefined;\n if (maxStringLength && maxStringLength > MAX_ALLOWED_STRING_LENGTH) {\n DEBUG_BUILD &&\n debug.warn(\n `\\`dom.maxStringLength\\` cannot exceed ${MAX_ALLOWED_STRING_LENGTH}, but a value of ${maxStringLength} was configured. Sentry will use ${MAX_ALLOWED_STRING_LENGTH} instead.`,\n );\n maxStringLength = MAX_ALLOWED_STRING_LENGTH;\n }\n\n if (typeof keyAttrs === 'string') {\n keyAttrs = [keyAttrs];\n }\n\n // Accessing event.target can throw (see getsentry/raven-js#838, #768)\n try {\n const event = handlerData.event ;\n const element = _isEvent(event) ? event.target : event;\n\n target = htmlTreeAsString(element, { keyAttrs, maxStringLength });\n componentName = getComponentName(element);\n } catch {\n target = '';\n }\n\n if (target.length === 0) {\n return;\n }\n\n const breadcrumb = {\n category: `ui.${handlerData.name}`,\n message: target,\n };\n\n if (componentName) {\n breadcrumb.data = { 'ui.component_name': componentName };\n }\n\n addBreadcrumb(breadcrumb, {\n event: handlerData.event,\n name: handlerData.name,\n global: handlerData.global,\n });\n };\n}\n\n/**\n * Creates breadcrumbs from console API calls\n */\nfunction _getConsoleBreadcrumbHandler(client) {\n return function _consoleBreadcrumb(handlerData) {\n if (getClient() !== client) {\n return;\n }\n\n const breadcrumb = {\n category: 'console',\n data: {\n arguments: handlerData.args,\n logger: 'console',\n },\n level: severityLevelFromString(handlerData.level),\n message: safeJoin(handlerData.args, ' '),\n };\n\n if (handlerData.level === 'assert') {\n if (handlerData.args[0] === false) {\n breadcrumb.message = `Assertion failed: ${safeJoin(handlerData.args.slice(1), ' ') || 'console.assert'}`;\n breadcrumb.data.arguments = handlerData.args.slice(1);\n } else {\n // Don't capture a breadcrumb for passed assertions\n return;\n }\n }\n\n addBreadcrumb(breadcrumb, {\n input: handlerData.args,\n level: handlerData.level,\n });\n };\n}\n\n/**\n * Creates breadcrumbs from XHR API calls\n */\nfunction _getXhrBreadcrumbHandler(client) {\n return function _xhrBreadcrumb(handlerData) {\n if (getClient() !== client) {\n return;\n }\n\n const { startTimestamp, endTimestamp } = handlerData;\n\n const sentryXhrData = handlerData.xhr[SENTRY_XHR_DATA_KEY];\n\n // We only capture complete, non-sentry requests\n if (!startTimestamp || !endTimestamp || !sentryXhrData) {\n return;\n }\n\n const { method, url, status_code, body } = sentryXhrData;\n\n const data = {\n method,\n url,\n status_code,\n };\n\n const hint = {\n xhr: handlerData.xhr,\n input: body,\n startTimestamp,\n endTimestamp,\n };\n\n const breadcrumb = {\n category: 'xhr',\n data,\n type: 'http',\n level: getBreadcrumbLogLevelFromHttpStatusCode(status_code),\n };\n\n client.emit('beforeOutgoingRequestBreadcrumb', breadcrumb, hint );\n\n addBreadcrumb(breadcrumb, hint);\n };\n}\n\n/**\n * Creates breadcrumbs from fetch API calls\n */\nfunction _getFetchBreadcrumbHandler(client) {\n return function _fetchBreadcrumb(handlerData) {\n if (getClient() !== client) {\n return;\n }\n\n const { startTimestamp, endTimestamp } = handlerData;\n\n // We only capture complete fetch requests\n if (!endTimestamp) {\n return;\n }\n\n if (handlerData.fetchData.url.match(/sentry_key/) && handlerData.fetchData.method === 'POST') {\n // We will not create breadcrumbs for fetch requests that contain `sentry_key` (internal sentry requests)\n return;\n }\n\n ({\n method: handlerData.fetchData.method,\n url: handlerData.fetchData.url,\n });\n\n if (handlerData.error) {\n const data = handlerData.fetchData;\n const hint = {\n data: handlerData.error,\n input: handlerData.args,\n startTimestamp,\n endTimestamp,\n };\n\n const breadcrumb = {\n category: 'fetch',\n data,\n level: 'error',\n type: 'http',\n } ;\n\n client.emit('beforeOutgoingRequestBreadcrumb', breadcrumb, hint );\n\n addBreadcrumb(breadcrumb, hint);\n } else {\n const response = handlerData.response ;\n const data = {\n ...handlerData.fetchData,\n status_code: response?.status,\n };\n\n handlerData.fetchData.request_body_size;\n handlerData.fetchData.response_body_size;\n response?.status;\n\n const hint = {\n input: handlerData.args,\n response,\n startTimestamp,\n endTimestamp,\n };\n\n const breadcrumb = {\n category: 'fetch',\n data,\n type: 'http',\n level: getBreadcrumbLogLevelFromHttpStatusCode(data.status_code),\n };\n\n client.emit('beforeOutgoingRequestBreadcrumb', breadcrumb, hint );\n\n addBreadcrumb(breadcrumb, hint);\n }\n };\n}\n\n/**\n * Creates breadcrumbs from history API calls\n */\nfunction _getHistoryBreadcrumbHandler(client) {\n return function _historyBreadcrumb(handlerData) {\n if (getClient() !== client) {\n return;\n }\n\n let from = handlerData.from;\n let to = handlerData.to;\n const parsedLoc = parseUrl(WINDOW.location.href);\n let parsedFrom = from ? parseUrl(from) : undefined;\n const parsedTo = parseUrl(to);\n\n // Initial pushState doesn't provide `from` information\n if (!parsedFrom?.path) {\n parsedFrom = parsedLoc;\n }\n\n // Use only the path component of the URL if the URL matches the current\n // document (almost all the time when using pushState)\n if (parsedLoc.protocol === parsedTo.protocol && parsedLoc.host === parsedTo.host) {\n to = parsedTo.relative;\n }\n if (parsedLoc.protocol === parsedFrom.protocol && parsedLoc.host === parsedFrom.host) {\n from = parsedFrom.relative;\n }\n\n addBreadcrumb({\n category: 'navigation',\n data: {\n from,\n to,\n },\n });\n };\n}\n\nfunction _isEvent(event) {\n return !!event && !!(event ).target;\n}\n\nexport { breadcrumbsIntegration };\n//# sourceMappingURL=breadcrumbs.js.map\n","import { defineIntegration, fill, getFunctionName, getOriginalFunction } from '@sentry/core';\nimport { WINDOW, wrap } from '../helpers.js';\n\nconst DEFAULT_EVENT_TARGET = [\n 'EventTarget',\n 'Window',\n 'Node',\n 'ApplicationCache',\n 'AudioTrackList',\n 'BroadcastChannel',\n 'ChannelMergerNode',\n 'CryptoOperation',\n 'EventSource',\n 'FileReader',\n 'HTMLUnknownElement',\n 'IDBDatabase',\n 'IDBRequest',\n 'IDBTransaction',\n 'KeyOperation',\n 'MediaController',\n 'MessagePort',\n 'ModalWindow',\n 'Notification',\n 'SVGElementInstance',\n 'Screen',\n 'SharedWorker',\n 'TextTrack',\n 'TextTrackCue',\n 'TextTrackList',\n 'WebSocket',\n 'WebSocketWorker',\n 'Worker',\n 'XMLHttpRequest',\n 'XMLHttpRequestEventTarget',\n 'XMLHttpRequestUpload',\n];\n\nconst INTEGRATION_NAME = 'BrowserApiErrors';\n\nconst _browserApiErrorsIntegration = ((options = {}) => {\n const _options = {\n XMLHttpRequest: true,\n eventTarget: true,\n requestAnimationFrame: true,\n setInterval: true,\n setTimeout: true,\n unregisterOriginalCallbacks: false,\n ...options,\n };\n\n return {\n name: INTEGRATION_NAME,\n // TODO: This currently only works for the first client this is setup\n // We may want to adjust this to check for client etc.\n setupOnce() {\n if (_options.setTimeout) {\n fill(WINDOW, 'setTimeout', _wrapTimeFunction);\n }\n\n if (_options.setInterval) {\n fill(WINDOW, 'setInterval', _wrapTimeFunction);\n }\n\n if (_options.requestAnimationFrame) {\n fill(WINDOW, 'requestAnimationFrame', _wrapRAF);\n }\n\n if (_options.XMLHttpRequest && 'XMLHttpRequest' in WINDOW) {\n fill(XMLHttpRequest.prototype, 'send', _wrapXHR);\n }\n\n const eventTargetOption = _options.eventTarget;\n if (eventTargetOption) {\n const eventTarget = Array.isArray(eventTargetOption) ? eventTargetOption : DEFAULT_EVENT_TARGET;\n eventTarget.forEach(target => _wrapEventTarget(target, _options));\n }\n },\n };\n}) ;\n\n/**\n * Wrap timer functions and event targets to catch errors and provide better meta data.\n */\nconst browserApiErrorsIntegration = defineIntegration(_browserApiErrorsIntegration);\n\nfunction _wrapTimeFunction(original) {\n return function ( ...args) {\n const originalCallback = args[0];\n args[0] = wrap(originalCallback, {\n mechanism: {\n handled: false,\n type: `auto.browser.browserapierrors.${getFunctionName(original)}`,\n },\n });\n return original.apply(this, args);\n };\n}\n\nfunction _wrapRAF(original) {\n return function ( callback) {\n return original.apply(this, [\n wrap(callback, {\n mechanism: {\n data: {\n handler: getFunctionName(original),\n },\n handled: false,\n type: 'auto.browser.browserapierrors.requestAnimationFrame',\n },\n }),\n ]);\n };\n}\n\nfunction _wrapXHR(originalSend) {\n return function ( ...args) {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const xhr = this;\n const xmlHttpRequestProps = ['onload', 'onerror', 'onprogress', 'onreadystatechange'];\n\n xmlHttpRequestProps.forEach(prop => {\n if (prop in xhr && typeof xhr[prop] === 'function') {\n fill(xhr, prop, function (original) {\n const wrapOptions = {\n mechanism: {\n data: {\n handler: getFunctionName(original),\n },\n handled: false,\n type: `auto.browser.browserapierrors.xhr.${prop}`,\n },\n };\n\n // If Instrument integration has been called before BrowserApiErrors, get the name of original function\n const originalFunction = getOriginalFunction(original);\n if (originalFunction) {\n wrapOptions.mechanism.data.handler = getFunctionName(originalFunction);\n }\n\n // Otherwise wrap directly\n return wrap(original, wrapOptions);\n });\n }\n });\n\n return originalSend.apply(this, args);\n };\n}\n\nfunction _wrapEventTarget(target, integrationOptions) {\n const globalObject = WINDOW ;\n const proto = globalObject[target]?.prototype;\n\n // eslint-disable-next-line no-prototype-builtins\n if (!proto?.hasOwnProperty?.('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (original)\n\n {\n return function ( eventName, fn, options) {\n try {\n if (isEventListenerObject(fn)) {\n // ESlint disable explanation:\n // First, it is generally safe to call `wrap` with an unbound function. Furthermore, using `.bind()` would\n // introduce a bug here, because bind returns a new function that doesn't have our\n // flags(like __sentry_original__) attached. `wrap` checks for those flags to avoid unnecessary wrapping.\n // Without those flags, every call to addEventListener wraps the function again, causing a memory leak.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n fn.handleEvent = wrap(fn.handleEvent, {\n mechanism: {\n data: {\n handler: getFunctionName(fn),\n target,\n },\n handled: false,\n type: 'auto.browser.browserapierrors.handleEvent',\n },\n });\n }\n } catch {\n // can sometimes get 'Permission denied to access property \"handle Event'\n }\n\n if (integrationOptions.unregisterOriginalCallbacks) {\n unregisterOriginalCallback(this, eventName, fn);\n }\n\n return original.apply(this, [\n eventName,\n wrap(fn, {\n mechanism: {\n data: {\n handler: getFunctionName(fn),\n target,\n },\n handled: false,\n type: 'auto.browser.browserapierrors.addEventListener',\n },\n }),\n options,\n ]);\n };\n });\n\n fill(proto, 'removeEventListener', function (originalRemoveEventListener)\n\n {\n return function ( eventName, fn, options) {\n /**\n * There are 2 possible scenarios here:\n *\n * 1. Someone passes a callback, which was attached prior to Sentry initialization, or by using unmodified\n * method, eg. `document.addEventListener.call(el, name, handler). In this case, we treat this function\n * as a pass-through, and call original `removeEventListener` with it.\n *\n * 2. Someone passes a callback, which was attached after Sentry was initialized, which means that it was using\n * our wrapped version of `addEventListener`, which internally calls `wrap` helper.\n * This helper \"wraps\" whole callback inside a try/catch statement, and attached appropriate metadata to it,\n * in order for us to make a distinction between wrapped/non-wrapped functions possible.\n * If a function was wrapped, it has additional property of `__sentry_wrapped__`, holding the handler.\n *\n * When someone adds a handler prior to initialization, and then do it again, but after,\n * then we have to detach both of them. Otherwise, if we'd detach only wrapped one, it'd be impossible\n * to get rid of the initial handler and it'd stick there forever.\n */\n try {\n const originalEventHandler = (fn ).__sentry_wrapped__;\n if (originalEventHandler) {\n originalRemoveEventListener.call(this, eventName, originalEventHandler, options);\n }\n } catch {\n // ignore, accessing __sentry_wrapped__ will throw in some Selenium environments\n }\n return originalRemoveEventListener.call(this, eventName, fn, options);\n };\n });\n}\n\nfunction isEventListenerObject(obj) {\n return typeof (obj ).handleEvent === 'function';\n}\n\nfunction unregisterOriginalCallback(target, eventName, fn) {\n if (\n target &&\n typeof target === 'object' &&\n 'removeEventListener' in target &&\n typeof target.removeEventListener === 'function'\n ) {\n target.removeEventListener(eventName, fn);\n }\n}\n\nexport { browserApiErrorsIntegration };\n//# sourceMappingURL=browserapierrors.js.map\n","import { defineIntegration, addGlobalErrorInstrumentationHandler, getClient, captureEvent, debug, addGlobalUnhandledRejectionInstrumentationHandler, isPrimitive, getLocationHref, UNKNOWN_FUNCTION, isString } from '@sentry/core';\nimport { DEBUG_BUILD } from '../debug-build.js';\nimport { eventFromUnknownInput } from '../eventbuilder.js';\nimport { shouldIgnoreOnError } from '../helpers.js';\n\nconst INTEGRATION_NAME = 'GlobalHandlers';\n\nconst _globalHandlersIntegration = ((options = {}) => {\n const _options = {\n onerror: true,\n onunhandledrejection: true,\n ...options,\n };\n\n return {\n name: INTEGRATION_NAME,\n setupOnce() {\n Error.stackTraceLimit = 50;\n },\n setup(client) {\n if (_options.onerror) {\n _installGlobalOnErrorHandler(client);\n globalHandlerLog('onerror');\n }\n if (_options.onunhandledrejection) {\n _installGlobalOnUnhandledRejectionHandler(client);\n globalHandlerLog('onunhandledrejection');\n }\n },\n };\n}) ;\n\nconst globalHandlersIntegration = defineIntegration(_globalHandlersIntegration);\n\nfunction _installGlobalOnErrorHandler(client) {\n addGlobalErrorInstrumentationHandler(data => {\n const { stackParser, attachStacktrace } = getOptions();\n\n if (getClient() !== client || shouldIgnoreOnError()) {\n return;\n }\n\n const { msg, url, line, column, error } = data;\n\n const event = _enhanceEventWithInitialFrame(\n eventFromUnknownInput(stackParser, error || msg, undefined, attachStacktrace, false),\n url,\n line,\n column,\n );\n\n event.level = 'error';\n\n captureEvent(event, {\n originalException: error,\n mechanism: {\n handled: false,\n type: 'auto.browser.global_handlers.onerror',\n },\n });\n });\n}\n\nfunction _installGlobalOnUnhandledRejectionHandler(client) {\n addGlobalUnhandledRejectionInstrumentationHandler(e => {\n const { stackParser, attachStacktrace } = getOptions();\n\n if (getClient() !== client || shouldIgnoreOnError()) {\n return;\n }\n\n const error = _getUnhandledRejectionError(e);\n\n const event = isPrimitive(error)\n ? _eventFromRejectionWithPrimitive(error)\n : eventFromUnknownInput(stackParser, error, undefined, attachStacktrace, true);\n\n event.level = 'error';\n\n captureEvent(event, {\n originalException: error,\n mechanism: {\n handled: false,\n type: 'auto.browser.global_handlers.onunhandledrejection',\n },\n });\n });\n}\n\nfunction _getUnhandledRejectionError(error) {\n if (isPrimitive(error)) {\n return error;\n }\n\n // dig the object of the rejection out of known event types\n try {\n\n // PromiseRejectionEvents store the object of the rejection under 'reason'\n // see https://developer.mozilla.org/en-US/docs/Web/API/PromiseRejectionEvent\n if ('reason' in (error )) {\n return (error ).reason;\n }\n\n // something, somewhere, (likely a browser extension) effectively casts PromiseRejectionEvents\n // to CustomEvents, moving the `promise` and `reason` attributes of the PRE into\n // the CustomEvent's `detail` attribute, since they're not part of CustomEvent's spec\n // see https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent and\n // https://github.com/getsentry/sentry-javascript/issues/2380\n if ('detail' in (error ) && 'reason' in (error ).detail) {\n return (error ).detail.reason;\n }\n } catch {} // eslint-disable-line no-empty\n\n return error;\n}\n\n/**\n * Create an event from a promise rejection where the `reason` is a primitive.\n *\n * @param reason: The `reason` property of the promise rejection\n * @returns An Event object with an appropriate `exception` value\n */\nfunction _eventFromRejectionWithPrimitive(reason) {\n return {\n exception: {\n values: [\n {\n type: 'UnhandledRejection',\n // String() is needed because the Primitive type includes symbols (which can't be automatically stringified)\n value: `Non-Error promise rejection captured with value: ${String(reason)}`,\n },\n ],\n },\n };\n}\n\nfunction _enhanceEventWithInitialFrame(\n event,\n url,\n line,\n column,\n) {\n // event.exception\n const e = (event.exception = event.exception || {});\n // event.exception.values\n const ev = (e.values = e.values || []);\n // event.exception.values[0]\n const ev0 = (ev[0] = ev[0] || {});\n // event.exception.values[0].stacktrace\n const ev0s = (ev0.stacktrace = ev0.stacktrace || {});\n // event.exception.values[0].stacktrace.frames\n const ev0sf = (ev0s.frames = ev0s.frames || []);\n\n const colno = column;\n const lineno = line;\n const filename = getFilenameFromUrl(url) ?? getLocationHref();\n\n // event.exception.values[0].stacktrace.frames\n if (ev0sf.length === 0) {\n ev0sf.push({\n colno,\n filename,\n function: UNKNOWN_FUNCTION,\n in_app: true,\n lineno,\n });\n }\n\n return event;\n}\n\nfunction globalHandlerLog(type) {\n DEBUG_BUILD && debug.log(`Global Handler attached: ${type}`);\n}\n\nfunction getOptions() {\n const client = getClient();\n const options = client?.getOptions() || {\n stackParser: () => [],\n attachStacktrace: false,\n };\n return options;\n}\n\nfunction getFilenameFromUrl(url) {\n if (!isString(url) || url.length === 0) {\n return undefined;\n }\n\n // stack frame urls can be data urls, for example when initializing a Worker with a base64 encoded script\n // in this case we just show the data prefix and mime type to avoid too long raw data urls\n if (url.startsWith('data:')) {\n const match = url.match(/^data:([^;]+)/);\n const mimeType = match ? match[1] : 'text/javascript';\n const isBase64 = url.includes('base64,');\n return ``;\n }\n\n return url.slice(0, 1024);\n}\n\nexport { globalHandlersIntegration };\n//# sourceMappingURL=globalhandlers.js.map\n","import { defineIntegration } from '@sentry/core';\nimport { WINDOW, getHttpRequestData } from '../helpers.js';\n\n/**\n * Collects information about HTTP request headers and\n * attaches them to the event.\n */\nconst httpContextIntegration = defineIntegration(() => {\n return {\n name: 'HttpContext',\n preprocessEvent(event) {\n // if none of the information we want exists, don't bother\n if (!WINDOW.navigator && !WINDOW.location && !WINDOW.document) {\n return;\n }\n\n const reqData = getHttpRequestData();\n const headers = {\n ...reqData.headers,\n ...event.request?.headers,\n };\n\n event.request = {\n ...reqData,\n ...event.request,\n headers,\n };\n },\n };\n});\n\nexport { httpContextIntegration };\n//# sourceMappingURL=httpcontext.js.map\n","import { defineIntegration, applyAggregateErrorsToEvent } from '@sentry/core';\nimport { exceptionFromError } from '../eventbuilder.js';\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\nconst INTEGRATION_NAME = 'LinkedErrors';\n\nconst _linkedErrorsIntegration = ((options = {}) => {\n const limit = options.limit || DEFAULT_LIMIT;\n const key = options.key || DEFAULT_KEY;\n\n return {\n name: INTEGRATION_NAME,\n preprocessEvent(event, hint, client) {\n const options = client.getOptions();\n\n applyAggregateErrorsToEvent(\n // This differs from the LinkedErrors integration in core by using a different exceptionFromError function\n exceptionFromError,\n options.stackParser,\n key,\n limit,\n event,\n hint,\n );\n },\n };\n}) ;\n\n/**\n * Aggregrate linked errors in an event.\n */\nconst linkedErrorsIntegration = defineIntegration(_linkedErrorsIntegration);\n\nexport { linkedErrorsIntegration };\n//# sourceMappingURL=linkederrors.js.map\n","import { defineIntegration, supportsNativeFetch, addFetchInstrumentationHandler, getClient, GLOBAL_OBJ, debug, captureEvent, isSentryRequestUrl, addExceptionMechanism } from '@sentry/core';\nimport { addXhrInstrumentationHandler, SENTRY_XHR_DATA_KEY } from '@sentry-internal/browser-utils';\nimport { DEBUG_BUILD } from '../debug-build.js';\n\nconst INTEGRATION_NAME = 'HttpClient';\n\nconst _httpClientIntegration = ((options = {}) => {\n const _options = {\n failedRequestStatusCodes: [[500, 599]],\n failedRequestTargets: [/.*/],\n ...options,\n };\n\n return {\n name: INTEGRATION_NAME,\n setup(client) {\n _wrapFetch(client, _options);\n _wrapXHR(client, _options);\n },\n };\n}) ;\n\n/**\n * Create events for failed client side HTTP requests.\n */\nconst httpClientIntegration = defineIntegration(_httpClientIntegration);\n\n/**\n * Interceptor function for fetch requests\n *\n * @param requestInfo The Fetch API request info\n * @param response The Fetch API response\n * @param requestInit The request init object\n */\nfunction _fetchResponseHandler(\n options,\n requestInfo,\n response,\n requestInit,\n error,\n) {\n if (_shouldCaptureResponse(options, response.status, response.url)) {\n const request = _getRequest(requestInfo, requestInit);\n\n let requestHeaders, responseHeaders, requestCookies, responseCookies;\n\n if (_shouldSendDefaultPii()) {\n [requestHeaders, requestCookies] = _parseCookieHeaders('Cookie', request);\n [responseHeaders, responseCookies] = _parseCookieHeaders('Set-Cookie', response);\n }\n\n const event = _createEvent({\n url: request.url,\n method: request.method,\n status: response.status,\n requestHeaders,\n responseHeaders,\n requestCookies,\n responseCookies,\n error,\n type: 'fetch',\n });\n\n captureEvent(event);\n }\n}\n\nfunction _parseCookieHeaders(\n cookieHeader,\n obj,\n) {\n const headers = _extractFetchHeaders(obj.headers);\n let cookies;\n\n try {\n const cookieString = headers[cookieHeader] || headers[cookieHeader.toLowerCase()] || undefined;\n\n if (cookieString) {\n cookies = _parseCookieString(cookieString);\n }\n } catch {\n // ignore it if parsing fails\n }\n\n return [headers, cookies];\n}\n\n/**\n * Interceptor function for XHR requests\n *\n * @param xhr The XHR request\n * @param method The HTTP method\n * @param headers The HTTP headers\n */\nfunction _xhrResponseHandler(\n options,\n xhr,\n method,\n headers,\n error,\n) {\n if (_shouldCaptureResponse(options, xhr.status, xhr.responseURL)) {\n let requestHeaders, responseCookies, responseHeaders;\n\n if (_shouldSendDefaultPii()) {\n try {\n const cookieString = xhr.getResponseHeader('Set-Cookie') || xhr.getResponseHeader('set-cookie') || undefined;\n\n if (cookieString) {\n responseCookies = _parseCookieString(cookieString);\n }\n } catch {\n // ignore it if parsing fails\n }\n\n try {\n responseHeaders = _getXHRResponseHeaders(xhr);\n } catch {\n // ignore it if parsing fails\n }\n\n requestHeaders = headers;\n }\n\n const event = _createEvent({\n url: xhr.responseURL,\n method,\n status: xhr.status,\n requestHeaders,\n // Can't access request cookies from XHR\n responseHeaders,\n responseCookies,\n error,\n type: 'xhr',\n });\n\n captureEvent(event);\n }\n}\n\n/**\n * Extracts response size from `Content-Length` header when possible\n *\n * @param headers\n * @returns The response size in bytes or undefined\n */\nfunction _getResponseSizeFromHeaders(headers) {\n if (headers) {\n const contentLength = headers['Content-Length'] || headers['content-length'];\n\n if (contentLength) {\n return parseInt(contentLength, 10);\n }\n }\n\n return undefined;\n}\n\n/**\n * Creates an object containing cookies from the given cookie string\n *\n * @param cookieString The cookie string to parse\n * @returns The parsed cookies\n */\nfunction _parseCookieString(cookieString) {\n return cookieString.split('; ').reduce((acc, cookie) => {\n const [key, value] = cookie.split('=');\n if (key && value) {\n acc[key] = value;\n }\n return acc;\n }, {});\n}\n\n/**\n * Extracts the headers as an object from the given Fetch API request or response object\n *\n * @param headers The headers to extract\n * @returns The extracted headers as an object\n */\nfunction _extractFetchHeaders(headers) {\n const result = {};\n\n headers.forEach((value, key) => {\n result[key] = value;\n });\n\n return result;\n}\n\n/**\n * Extracts the response headers as an object from the given XHR object\n *\n * @param xhr The XHR object to extract the response headers from\n * @returns The response headers as an object\n */\nfunction _getXHRResponseHeaders(xhr) {\n const headers = xhr.getAllResponseHeaders();\n\n if (!headers) {\n return {};\n }\n\n return headers.split('\\r\\n').reduce((acc, line) => {\n const [key, value] = line.split(': ');\n if (key && value) {\n acc[key] = value;\n }\n return acc;\n }, {});\n}\n\n/**\n * Checks if the given target url is in the given list of targets\n *\n * @param target The target url to check\n * @returns true if the target url is in the given list of targets, false otherwise\n */\nfunction _isInGivenRequestTargets(\n failedRequestTargets,\n target,\n) {\n return failedRequestTargets.some((givenRequestTarget) => {\n if (typeof givenRequestTarget === 'string') {\n return target.includes(givenRequestTarget);\n }\n\n return givenRequestTarget.test(target);\n });\n}\n\n/**\n * Checks if the given status code is in the given range\n *\n * @param status The status code to check\n * @returns true if the status code is in the given range, false otherwise\n */\nfunction _isInGivenStatusRanges(\n failedRequestStatusCodes,\n status,\n) {\n return failedRequestStatusCodes.some((range) => {\n if (typeof range === 'number') {\n return range === status;\n }\n\n return status >= range[0] && status <= range[1];\n });\n}\n\n/**\n * Wraps `fetch` function to capture request and response data\n */\nfunction _wrapFetch(client, options) {\n if (!supportsNativeFetch()) {\n return;\n }\n\n addFetchInstrumentationHandler(handlerData => {\n if (getClient() !== client) {\n return;\n }\n\n const { response, args, error, virtualError } = handlerData;\n const [requestInfo, requestInit] = args ;\n\n if (!response) {\n return;\n }\n\n _fetchResponseHandler(options, requestInfo, response , requestInit, error || virtualError);\n }, false);\n}\n\n/**\n * Wraps XMLHttpRequest to capture request and response data\n */\nfunction _wrapXHR(client, options) {\n if (!('XMLHttpRequest' in GLOBAL_OBJ)) {\n return;\n }\n\n addXhrInstrumentationHandler(handlerData => {\n if (getClient() !== client) {\n return;\n }\n\n const { error, virtualError } = handlerData;\n\n const xhr = handlerData.xhr ;\n\n const sentryXhrData = xhr[SENTRY_XHR_DATA_KEY];\n\n if (!sentryXhrData) {\n return;\n }\n\n const { method, request_headers: headers } = sentryXhrData;\n\n try {\n _xhrResponseHandler(options, xhr, method, headers, error || virtualError);\n } catch (e) {\n DEBUG_BUILD && debug.warn('Error while extracting response event form XHR response', e);\n }\n });\n}\n\n/**\n * Checks whether to capture given response as an event\n *\n * @param status response status code\n * @param url response url\n */\nfunction _shouldCaptureResponse(options, status, url) {\n return (\n _isInGivenStatusRanges(options.failedRequestStatusCodes, status) &&\n _isInGivenRequestTargets(options.failedRequestTargets, url) &&\n !isSentryRequestUrl(url, getClient())\n );\n}\n\n/**\n * Creates a synthetic Sentry event from given response data\n *\n * @param data response data\n * @returns event\n */\nfunction _createEvent(data\n\n) {\n const client = getClient();\n const virtualStackTrace = client && data.error && data.error instanceof Error ? data.error.stack : undefined;\n // Remove the first frame from the stack as it's the HttpClient call\n const stack = virtualStackTrace && client ? client.getOptions().stackParser(virtualStackTrace, 0, 1) : undefined;\n const message = `HTTP Client Error with status code: ${data.status}`;\n\n const event = {\n message,\n exception: {\n values: [\n {\n type: 'Error',\n value: message,\n stacktrace: stack ? { frames: stack } : undefined,\n },\n ],\n },\n request: {\n url: data.url,\n method: data.method,\n headers: data.requestHeaders,\n cookies: data.requestCookies,\n },\n contexts: {\n response: {\n status_code: data.status,\n headers: data.responseHeaders,\n cookies: data.responseCookies,\n body_size: _getResponseSizeFromHeaders(data.responseHeaders),\n },\n },\n };\n\n addExceptionMechanism(event, {\n type: `auto.http.client.${data.type}`,\n handled: false,\n });\n\n return event;\n}\n\nfunction _getRequest(requestInfo, requestInit) {\n if (!requestInit && requestInfo instanceof Request) {\n return requestInfo;\n }\n\n // If both are set, we try to construct a new Request with the given arguments\n // However, if e.g. the original request has a `body`, this will throw an error because it was already accessed\n // In this case, as a fallback, we just use the original request - using both is rather an edge case\n if (requestInfo instanceof Request && requestInfo.bodyUsed) {\n return requestInfo;\n }\n\n return new Request(requestInfo, requestInit);\n}\n\nfunction _shouldSendDefaultPii() {\n const client = getClient();\n return client ? Boolean(client.getOptions().sendDefaultPii) : false;\n}\n\nexport { httpClientIntegration };\n//# sourceMappingURL=httpclient.js.map\n","/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nconst DEBUG_BUILD = (typeof __SENTRY_DEBUG__ === 'undefined' || __SENTRY_DEBUG__);\n\nexport { DEBUG_BUILD };\n//# sourceMappingURL=debug-build.js.map\n","/** Internal global with common properties and Sentry extensions */\n\n/** Get's the global object for the current JavaScript runtime */\nconst GLOBAL_OBJ = globalThis ;\n\nexport { GLOBAL_OBJ };\n//# sourceMappingURL=worldwide.js.map\n","// This is a magic string replaced by rollup\n\nconst SDK_VERSION = \"9.46.0\" ;\n\nexport { SDK_VERSION };\n//# sourceMappingURL=version.js.map\n","import { SDK_VERSION } from './utils/version.js';\nimport { GLOBAL_OBJ } from './utils/worldwide.js';\n\n/**\n * An object that contains globally accessible properties and maintains a scope stack.\n * @hidden\n */\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nfunction getMainCarrier() {\n // This ensures a Sentry carrier exists\n getSentryCarrier(GLOBAL_OBJ);\n return GLOBAL_OBJ;\n}\n\n/** Will either get the existing sentry carrier, or create a new one. */\nfunction getSentryCarrier(carrier) {\n const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n\n // For now: First SDK that sets the .version property wins\n __SENTRY__.version = __SENTRY__.version || SDK_VERSION;\n\n // Intentionally populating and returning the version of \"this\" SDK instance\n // rather than what's set in .version so that \"this\" SDK always gets its carrier\n return (__SENTRY__[SDK_VERSION] = __SENTRY__[SDK_VERSION] || {});\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__[]` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nfunction getGlobalSingleton(\n name,\n creator,\n obj = GLOBAL_OBJ,\n) {\n const __SENTRY__ = (obj.__SENTRY__ = obj.__SENTRY__ || {});\n const carrier = (__SENTRY__[SDK_VERSION] = __SENTRY__[SDK_VERSION] || {});\n // Note: We do not want to set `carrier.version` here, as this may be called before any `init` is called, e.g. for the default scopes\n return carrier[name] || (carrier[name] = creator());\n}\n\nexport { getGlobalSingleton, getMainCarrier, getSentryCarrier };\n//# sourceMappingURL=carrier.js.map\n","import { getGlobalSingleton } from '../carrier.js';\nimport { DEBUG_BUILD } from '../debug-build.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\n/**\n * A Sentry Logger instance.\n *\n * @deprecated Use {@link debug} instead with the {@link SentryDebugLogger} type.\n */\n\nconst CONSOLE_LEVELS = [\n 'debug',\n 'info',\n 'warn',\n 'error',\n 'log',\n 'assert',\n 'trace',\n] ;\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\n/** This may be mutated by the console instrumentation. */\nconst originalConsoleMethods\n\n = {};\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nfunction consoleSandbox(callback) {\n if (!('console' in GLOBAL_OBJ)) {\n return callback();\n }\n\n const console = GLOBAL_OBJ.console ;\n const wrappedFuncs = {};\n\n const wrappedLevels = Object.keys(originalConsoleMethods) ;\n\n // Restore all wrapped console methods\n wrappedLevels.forEach(level => {\n const originalConsoleMethod = originalConsoleMethods[level];\n wrappedFuncs[level] = console[level] ;\n console[level] = originalConsoleMethod ;\n });\n\n try {\n return callback();\n } finally {\n // Revert restoration to wrapped state\n wrappedLevels.forEach(level => {\n console[level] = wrappedFuncs[level] ;\n });\n }\n}\n\nfunction enable() {\n _getLoggerSettings().enabled = true;\n}\n\nfunction disable() {\n _getLoggerSettings().enabled = false;\n}\n\nfunction isEnabled() {\n return _getLoggerSettings().enabled;\n}\n\nfunction log(...args) {\n _maybeLog('log', ...args);\n}\n\nfunction info(...args) {\n _maybeLog('info', ...args);\n}\n\nfunction warn(...args) {\n _maybeLog('warn', ...args);\n}\n\nfunction error(...args) {\n _maybeLog('error', ...args);\n}\n\nfunction _debug(...args) {\n _maybeLog('debug', ...args);\n}\n\nfunction assert(...args) {\n _maybeLog('assert', ...args);\n}\n\nfunction trace(...args) {\n _maybeLog('trace', ...args);\n}\n\nfunction _maybeLog(level, ...args) {\n if (!DEBUG_BUILD) {\n return;\n }\n\n if (isEnabled()) {\n consoleSandbox(() => {\n GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args);\n });\n }\n}\n\nfunction _getLoggerSettings() {\n if (!DEBUG_BUILD) {\n return { enabled: false };\n }\n\n return getGlobalSingleton('loggerSettings', () => ({ enabled: false }));\n}\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n * The logger is a singleton on the carrier, to ensure that a consistent logger is used throughout the SDK.\n *\n * @deprecated Use {@link debug} instead.\n */\nconst logger = {\n /** Enable logging. */\n enable,\n /** Disable logging. */\n disable,\n /** Check if logging is enabled. */\n isEnabled,\n /** Log a message. */\n log,\n /** Log level info */\n info,\n /** Log a warning. */\n warn,\n /** Log an error. */\n error,\n /** Log a debug message. */\n debug: _debug,\n /** Log an assertion. */\n assert,\n /** Log a trace. */\n trace,\n // eslint-disable-next-line deprecation/deprecation\n} ;\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n */\nconst debug = {\n /** Enable logging. */\n enable,\n /** Disable logging. */\n disable,\n /** Check if logging is enabled. */\n isEnabled,\n /** Log a message. */\n log,\n /** Log a warning. */\n warn,\n /** Log an error. */\n error,\n} ;\n\nexport { CONSOLE_LEVELS, consoleSandbox, debug, logger, originalConsoleMethods };\n//# sourceMappingURL=debug-logger.js.map\n","const STACKTRACE_FRAME_LIMIT = 50;\nconst UNKNOWN_FUNCTION = '?';\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nfunction createStackParser(...parsers) {\n const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n return (stack, skipFirstLines = 0, framesToPop = 0) => {\n const frames = [];\n const lines = stack.split('\\n');\n\n for (let i = skipFirstLines; i < lines.length; i++) {\n const line = lines[i] ;\n // Ignore lines over 1kb as they are unlikely to be stack frames.\n // Many of the regular expressions use backtracking which results in run time that increases exponentially with\n // input size. Huge strings can result in hangs/Denial of Service:\n // https://github.com/getsentry/sentry-javascript/issues/2286\n if (line.length > 1024) {\n continue;\n }\n\n // https://github.com/getsentry/sentry-javascript/issues/5459\n // Remove webpack (error: *) wrappers\n const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n // https://github.com/getsentry/sentry-javascript/issues/7813\n // Skip Error: lines\n if (cleanedLine.match(/\\S*Error: /)) {\n continue;\n }\n\n for (const parser of sortedParsers) {\n const frame = parser(cleanedLine);\n\n if (frame) {\n frames.push(frame);\n break;\n }\n }\n\n if (frames.length >= STACKTRACE_FRAME_LIMIT + framesToPop) {\n break;\n }\n }\n\n return stripSentryFramesAndReverse(frames.slice(framesToPop));\n };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nfunction stackParserFromStackParserOptions(stackParser) {\n if (Array.isArray(stackParser)) {\n return createStackParser(...stackParser);\n }\n return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nfunction stripSentryFramesAndReverse(stack) {\n if (!stack.length) {\n return [];\n }\n\n const localStack = Array.from(stack);\n\n // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n if (/sentryWrapped/.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n }\n\n // Reversing in the middle of the procedure allows us to just pop the values off the stack\n localStack.reverse();\n\n // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n\n // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n // is produced within the scope itself, making it:\n //\n // Sentry.captureException()\n // scope.captureException()\n //\n // instead of just the top `Sentry` call itself.\n // This forces us to possibly strip an additional frame in the exact same was as above.\n if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n localStack.pop();\n }\n }\n\n return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n ...frame,\n filename: frame.filename || getLastStackFrame(localStack).filename,\n function: frame.function || UNKNOWN_FUNCTION,\n }));\n}\n\nfunction getLastStackFrame(arr) {\n return arr[arr.length - 1] || {};\n}\n\nconst defaultFunctionName = '';\n\n/**\n * Safely extract function name from itself\n */\nfunction getFunctionName(fn) {\n try {\n if (!fn || typeof fn !== 'function') {\n return defaultFunctionName;\n }\n return fn.name || defaultFunctionName;\n } catch {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n return defaultFunctionName;\n }\n}\n\n/**\n * Get's stack frames from an event without needing to check for undefined properties.\n */\nfunction getFramesFromEvent(event) {\n const exception = event.exception;\n\n if (exception) {\n const frames = [];\n try {\n // @ts-expect-error Object could be undefined\n exception.values.forEach(value => {\n // @ts-expect-error Value could be undefined\n if (value.stacktrace.frames) {\n // @ts-expect-error Value could be undefined\n frames.push(...value.stacktrace.frames);\n }\n });\n return frames;\n } catch {\n return undefined;\n }\n }\n return undefined;\n}\n\nexport { UNKNOWN_FUNCTION, createStackParser, getFramesFromEvent, getFunctionName, stackParserFromStackParserOptions, stripSentryFramesAndReverse };\n//# sourceMappingURL=stacktrace.js.map\n","// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isError(wat) {\n switch (objectToString.call(wat)) {\n case '[object Error]':\n case '[object Exception]':\n case '[object DOMException]':\n case '[object WebAssembly.Exception]':\n return true;\n default:\n return isInstanceOf(wat, Error);\n }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat, className) {\n return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isErrorEvent(wat) {\n return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMError(wat) {\n return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMException(wat) {\n return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isString(wat) {\n return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given string is parameterized\n * {@link isParameterizedString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isParameterizedString(wat) {\n return (\n typeof wat === 'object' &&\n wat !== null &&\n '__sentry_template_string__' in wat &&\n '__sentry_template_values__' in wat\n );\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPrimitive(wat) {\n return wat === null || isParameterizedString(wat) || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal, or a class instance.\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPlainObject(wat) {\n return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isEvent(wat) {\n return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isElement(wat) {\n return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isRegExp(wat) {\n return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nfunction isThenable(wat) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return Boolean(wat?.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isSyntheticEvent(wat) {\n return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nfunction isInstanceOf(wat, base) {\n try {\n return wat instanceof base;\n } catch {\n return false;\n }\n}\n\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isVueViewModel(wat) {\n // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n return !!(typeof wat === 'object' && wat !== null && ((wat ).__isVue || (wat )._isVue));\n}\n\n/**\n * Checks whether the given parameter is a Standard Web API Request instance.\n *\n * Returns false if Request is not available in the current runtime.\n */\nfunction isRequest(request) {\n return typeof Request !== 'undefined' && isInstanceOf(request, Request);\n}\n\nexport { isDOMError, isDOMException, isElement, isError, isErrorEvent, isEvent, isInstanceOf, isParameterizedString, isPlainObject, isPrimitive, isRegExp, isRequest, isString, isSyntheticEvent, isThenable, isVueViewModel };\n//# sourceMappingURL=is.js.map\n","import { isString } from './is.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\nconst WINDOW = GLOBAL_OBJ ;\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction htmlTreeAsString(\n elem,\n options = {},\n) {\n if (!elem) {\n return '';\n }\n\n // try/catch both:\n // - accessing event.target (see getsentry/raven-js#838, #768)\n // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n // - can throw an exception in some circumstances.\n try {\n let currentElem = elem ;\n const MAX_TRAVERSE_HEIGHT = 5;\n const out = [];\n let height = 0;\n let len = 0;\n const separator = ' > ';\n const sepLength = separator.length;\n let nextStr;\n const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n nextStr = _htmlElementAsString(currentElem, keyAttrs);\n // bail out if\n // - nextStr is the 'html' element\n // - the length of the string that would be created exceeds maxStringLength\n // (ignore this limit if we are on the first iteration)\n if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n break;\n }\n\n out.push(nextStr);\n\n len += nextStr.length;\n currentElem = currentElem.parentNode;\n }\n\n return out.reverse().join(separator);\n } catch {\n return '';\n }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el, keyAttrs) {\n const elem = el\n\n;\n\n const out = [];\n\n if (!elem?.tagName) {\n return '';\n }\n\n // @ts-expect-error WINDOW has HTMLElement\n if (WINDOW.HTMLElement) {\n // If using the component name annotation plugin, this value may be available on the DOM node\n if (elem instanceof HTMLElement && elem.dataset) {\n if (elem.dataset['sentryComponent']) {\n return elem.dataset['sentryComponent'];\n }\n if (elem.dataset['sentryElement']) {\n return elem.dataset['sentryElement'];\n }\n }\n }\n\n out.push(elem.tagName.toLowerCase());\n\n // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n const keyAttrPairs = keyAttrs?.length\n ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n : null;\n\n if (keyAttrPairs?.length) {\n keyAttrPairs.forEach(keyAttrPair => {\n out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n });\n } else {\n if (elem.id) {\n out.push(`#${elem.id}`);\n }\n\n const className = elem.className;\n if (className && isString(className)) {\n const classes = className.split(/\\s+/);\n for (const c of classes) {\n out.push(`.${c}`);\n }\n }\n }\n const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n for (const k of allowedAttrs) {\n const attr = elem.getAttribute(k);\n if (attr) {\n out.push(`[${k}=\"${attr}\"]`);\n }\n }\n\n return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nfunction getLocationHref() {\n try {\n return WINDOW.document.location.href;\n } catch {\n return '';\n }\n}\n\n/**\n * Given a DOM element, traverses up the tree until it finds the first ancestor node\n * that has the `data-sentry-component` or `data-sentry-element` attribute with `data-sentry-component` taking\n * precedence. This attribute is added at build-time by projects that have the component name annotation plugin installed.\n *\n * @returns a string representation of the component for the provided DOM element, or `null` if not found\n */\nfunction getComponentName(elem) {\n // @ts-expect-error WINDOW has HTMLElement\n if (!WINDOW.HTMLElement) {\n return null;\n }\n\n let currentElem = elem ;\n const MAX_TRAVERSE_HEIGHT = 5;\n for (let i = 0; i < MAX_TRAVERSE_HEIGHT; i++) {\n if (!currentElem) {\n return null;\n }\n\n if (currentElem instanceof HTMLElement) {\n if (currentElem.dataset['sentryComponent']) {\n return currentElem.dataset['sentryComponent'];\n }\n if (currentElem.dataset['sentryElement']) {\n return currentElem.dataset['sentryElement'];\n }\n }\n\n currentElem = currentElem.parentNode;\n }\n\n return null;\n}\n\nexport { getComponentName, getLocationHref, htmlTreeAsString };\n//# sourceMappingURL=browser.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { htmlTreeAsString } from './browser.js';\nimport { debug } from './debug-logger.js';\nimport { isError, isEvent, isInstanceOf, isPrimitive, isElement } from './is.js';\nimport { truncate } from './string.js';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * If the method on the passed object is not a function, the wrapper will not be applied.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, )` or `origMethod.apply(this, [])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nfunction fill(source, name, replacementFactory) {\n if (!(name in source)) {\n return;\n }\n\n // explicitly casting to unknown because we don't know the type of the method initially at all\n const original = source[name] ;\n\n if (typeof original !== 'function') {\n return;\n }\n\n const wrapped = replacementFactory(original) ;\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (typeof wrapped === 'function') {\n markFunctionWrapped(wrapped, original);\n }\n\n try {\n source[name] = wrapped;\n } catch {\n DEBUG_BUILD && debug.log(`Failed to replace method \"${name}\" in object`, source);\n }\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nfunction addNonEnumerableProperty(obj, name, value) {\n try {\n Object.defineProperty(obj, name, {\n // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n value: value,\n writable: true,\n configurable: true,\n });\n } catch {\n DEBUG_BUILD && debug.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nfunction markFunctionWrapped(wrapped, original) {\n try {\n const proto = original.prototype || {};\n wrapped.prototype = original.prototype = proto;\n addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n } catch {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available. See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction getOriginalFunction(func) {\n return func.__sentry_original__;\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor\n * an Error.\n */\nfunction convertToPlainObject(value)\n\n {\n if (isError(value)) {\n return {\n message: value.message,\n name: value.name,\n stack: value.stack,\n ...getOwnProperties(value),\n };\n } else if (isEvent(value)) {\n const newObj\n\n = {\n type: value.type,\n target: serializeEventTarget(value.target),\n currentTarget: serializeEventTarget(value.currentTarget),\n ...getOwnProperties(value),\n };\n\n if (typeof CustomEvent !== 'undefined' && isInstanceOf(value, CustomEvent)) {\n newObj.detail = value.detail;\n }\n\n return newObj;\n } else {\n return value;\n }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target) {\n try {\n return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target);\n } catch {\n return '';\n }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj) {\n if (typeof obj === 'object' && obj !== null) {\n const extractedProps = {};\n for (const property in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, property)) {\n extractedProps[property] = (obj )[property];\n }\n }\n return extractedProps;\n } else {\n return {};\n }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nfunction extractExceptionKeysForMessage(exception, maxLength = 40) {\n const keys = Object.keys(convertToPlainObject(exception));\n keys.sort();\n\n const firstKey = keys[0];\n\n if (!firstKey) {\n return '[object has no keys]';\n }\n\n if (firstKey.length >= maxLength) {\n return truncate(firstKey, maxLength);\n }\n\n for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n const serialized = keys.slice(0, includedKeys).join(', ');\n if (serialized.length > maxLength) {\n continue;\n }\n if (includedKeys === keys.length) {\n return serialized;\n }\n return truncate(serialized, maxLength);\n }\n\n return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n *\n * @deprecated This function is no longer used by the SDK and will be removed in a future major version.\n */\nfunction dropUndefinedKeys(inputValue) {\n // This map keeps track of what already visited nodes map to.\n // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n // references as the input object.\n const memoizationMap = new Map();\n\n // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys(inputValue, memoizationMap) {\n // Early return for primitive values\n if (inputValue === null || typeof inputValue !== 'object') {\n return inputValue;\n }\n\n // Check memo map first for all object types\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal ;\n }\n\n // handle arrays\n if (Array.isArray(inputValue)) {\n const returnValue = [];\n // Store mapping to handle circular references\n memoizationMap.set(inputValue, returnValue);\n\n inputValue.forEach(value => {\n returnValue.push(_dropUndefinedKeys(value, memoizationMap));\n });\n\n return returnValue ;\n }\n\n if (isPojo(inputValue)) {\n const returnValue = {};\n // Store mapping to handle circular references\n memoizationMap.set(inputValue, returnValue);\n\n const keys = Object.keys(inputValue);\n\n keys.forEach(key => {\n const val = inputValue[key];\n if (val !== undefined) {\n returnValue[key] = _dropUndefinedKeys(val, memoizationMap);\n }\n });\n\n return returnValue ;\n }\n\n // For other object types, return as is\n return inputValue;\n}\n\nfunction isPojo(input) {\n // Plain objects have Object as constructor or no constructor\n const constructor = (input ).constructor;\n return constructor === Object || constructor === undefined;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nfunction objectify(wat) {\n let objectified;\n switch (true) {\n // this will catch both undefined and null\n case wat == undefined:\n objectified = new String(wat);\n break;\n\n // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n // an object in order to wrap it.\n case typeof wat === 'symbol' || typeof wat === 'bigint':\n objectified = Object(wat);\n break;\n\n // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n case isPrimitive(wat):\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n objectified = new (wat ).constructor(wat);\n break;\n\n // by process of elimination, at this point we know that `wat` must already be an object\n default:\n objectified = wat;\n break;\n }\n return objectified;\n}\n\nexport { addNonEnumerableProperty, convertToPlainObject, dropUndefinedKeys, extractExceptionKeysForMessage, fill, getOriginalFunction, markFunctionWrapped, objectify };\n//# sourceMappingURL=object.js.map\n","import { isVueViewModel, isSyntheticEvent } from './is.js';\nimport { convertToPlainObject } from './object.js';\nimport { getFunctionName } from './stacktrace.js';\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normalized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction normalize(input, depth = 100, maxProperties = +Infinity) {\n try {\n // since we're at the outermost level, we don't provide a key\n return visit('', input, depth, maxProperties);\n } catch (err) {\n return { ERROR: `**non-serializable** (${err})` };\n }\n}\n\n/** JSDoc */\nfunction normalizeToSize(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n object,\n // Default Node.js REPL depth\n depth = 3,\n // 100kB, as 200kB is max payload size, so half sounds reasonable\n maxSize = 100 * 1024,\n) {\n const normalized = normalize(object, depth);\n\n if (jsonSize(normalized) > maxSize) {\n return normalizeToSize(object, depth - 1, maxSize);\n }\n\n return normalized ;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n key,\n value,\n depth = +Infinity,\n maxProperties = +Infinity,\n memo = memoBuilder(),\n) {\n const [memoize, unmemoize] = memo;\n\n // Get the simple cases out of the way first\n if (\n value == null || // this matches null and undefined -> eqeq not eqeqeq\n ['boolean', 'string'].includes(typeof value) ||\n (typeof value === 'number' && Number.isFinite(value))\n ) {\n return value ;\n }\n\n const stringified = stringifyValue(key, value);\n\n // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n if (!stringified.startsWith('[object ')) {\n return stringified;\n }\n\n // From here on, we can assert that `value` is either an object or an array.\n\n // Do not normalize objects that we know have already been normalized. As a general rule, the\n // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n // have already been normalized.\n if ((value )['__sentry_skip_normalization__']) {\n return value ;\n }\n\n // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n // We keep a certain amount of depth.\n // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n const remainingDepth =\n typeof (value )['__sentry_override_normalization_depth__'] === 'number'\n ? ((value )['__sentry_override_normalization_depth__'] )\n : depth;\n\n // We're also done if we've reached the max depth\n if (remainingDepth === 0) {\n // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n return stringified.replace('object ', '');\n }\n\n // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n if (memoize(value)) {\n return '[Circular ~]';\n }\n\n // If the value has a `toJSON` method, we call it to extract more information\n const valueWithToJSON = value ;\n if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n try {\n const jsonValue = valueWithToJSON.toJSON();\n // We need to normalize the return value of `.toJSON()` in case it has circular references\n return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n } catch {\n // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n }\n }\n\n // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n // property/entry, and keep track of the number of items we add to it.\n const normalized = (Array.isArray(value) ? [] : {}) ;\n let numAdded = 0;\n\n // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n // properties are non-enumerable and otherwise would get missed.\n const visitable = convertToPlainObject(value );\n\n for (const visitKey in visitable) {\n // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n continue;\n }\n\n if (numAdded >= maxProperties) {\n normalized[visitKey] = '[MaxProperties ~]';\n break;\n }\n\n // Recursively visit all the child nodes\n const visitValue = visitable[visitKey];\n normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n numAdded++;\n }\n\n // Once we've visited all the branches, remove the parent from memo storage\n unmemoize(value);\n\n // Return accumulated values\n return normalized;\n}\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n key,\n // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n // our internal use, it'll do\n value,\n) {\n try {\n if (key === 'domain' && value && typeof value === 'object' && (value )._events) {\n return '[Domain]';\n }\n\n if (key === 'domainEmitter') {\n return '[DomainEmitter]';\n }\n\n // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n // which won't throw if they are not present.\n\n if (typeof global !== 'undefined' && value === global) {\n return '[Global]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof window !== 'undefined' && value === window) {\n return '[Window]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof document !== 'undefined' && value === document) {\n return '[Document]';\n }\n\n if (isVueViewModel(value)) {\n return '[VueViewModel]';\n }\n\n // React's SyntheticEvent thingy\n if (isSyntheticEvent(value)) {\n return '[SyntheticEvent]';\n }\n\n if (typeof value === 'number' && !Number.isFinite(value)) {\n return `[${value}]`;\n }\n\n if (typeof value === 'function') {\n return `[Function: ${getFunctionName(value)}]`;\n }\n\n if (typeof value === 'symbol') {\n return `[${String(value)}]`;\n }\n\n // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n if (typeof value === 'bigint') {\n return `[BigInt: ${String(value)}]`;\n }\n\n // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n // we can make sure that only plain objects come out that way.\n const objName = getConstructorName(value);\n\n // Handle HTML Elements\n if (/^HTML(\\w*)Element$/.test(objName)) {\n return `[HTMLElement: ${objName}]`;\n }\n\n return `[object ${objName}]`;\n } catch (err) {\n return `**non-serializable** (${err})`;\n }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value) {\n const prototype = Object.getPrototypeOf(value);\n\n return prototype?.constructor ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value) {\n // eslint-disable-next-line no-bitwise\n return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value) {\n return utf8Length(JSON.stringify(value));\n}\n\n/**\n * Normalizes URLs in exceptions and stacktraces to a base path so Sentry can fingerprint\n * across platforms and working directory.\n *\n * @param url The URL to be normalized.\n * @param basePath The application base path.\n * @returns The normalized URL.\n */\nfunction normalizeUrlToBase(url, basePath) {\n const escapedBase = basePath\n // Backslash to forward\n .replace(/\\\\/g, '/')\n // Escape RegExp special characters\n .replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n\n let newUrl = url;\n try {\n newUrl = decodeURI(url);\n } catch {\n // Sometime this breaks\n }\n return (\n newUrl\n .replace(/\\\\/g, '/')\n .replace(/webpack:\\/?/g, '') // Remove intermediate base path\n // eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor\n .replace(new RegExp(`(file://)?/*${escapedBase}/*`, 'ig'), 'app:///')\n );\n}\n\n/**\n * Helper to decycle json objects\n */\nfunction memoBuilder() {\n const inner = new WeakSet();\n function memoize(obj) {\n if (inner.has(obj)) {\n return true;\n }\n inner.add(obj);\n return false;\n }\n\n function unmemoize(obj) {\n inner.delete(obj);\n }\n return [memoize, unmemoize];\n}\n\nexport { normalize, normalizeToSize, normalizeUrlToBase };\n//# sourceMappingURL=normalize.js.map\n","import { getSentryCarrier } from '../carrier.js';\nimport { dsnToString } from './dsn.js';\nimport { normalize } from './normalize.js';\nimport { GLOBAL_OBJ } from './worldwide.js';\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction createEnvelope(headers, items = []) {\n return [headers, items] ;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction addItemToEnvelope(envelope, newItem) {\n const [headers, items] = envelope;\n return [headers, [...items, newItem]] ;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nfunction forEachEnvelopeItem(\n envelope,\n callback,\n) {\n const envelopeItems = envelope[1];\n\n for (const envelopeItem of envelopeItems) {\n const envelopeItemType = envelopeItem[0].type;\n const result = callback(envelopeItem, envelopeItemType);\n\n if (result) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nfunction envelopeContainsItemType(envelope, types) {\n return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8 array.\n */\nfunction encodeUTF8(input) {\n const carrier = getSentryCarrier(GLOBAL_OBJ);\n return carrier.encodePolyfill ? carrier.encodePolyfill(input) : new TextEncoder().encode(input);\n}\n\n/**\n * Decode a UTF8 array to string.\n */\nfunction decodeUTF8(input) {\n const carrier = getSentryCarrier(GLOBAL_OBJ);\n return carrier.decodePolyfill ? carrier.decodePolyfill(input) : new TextDecoder().decode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nfunction serializeEnvelope(envelope) {\n const [envHeaders, items] = envelope;\n // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n let parts = JSON.stringify(envHeaders);\n\n function append(next) {\n if (typeof parts === 'string') {\n parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts), next];\n } else {\n parts.push(typeof next === 'string' ? encodeUTF8(next) : next);\n }\n }\n\n for (const item of items) {\n const [itemHeaders, payload] = item;\n\n append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n if (typeof payload === 'string' || payload instanceof Uint8Array) {\n append(payload);\n } else {\n let stringifiedPayload;\n try {\n stringifiedPayload = JSON.stringify(payload);\n } catch {\n // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.stringify()` still\n // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n // performance impact but in this case a performance hit is better than throwing.\n stringifiedPayload = JSON.stringify(normalize(payload));\n }\n append(stringifiedPayload);\n }\n }\n\n return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers) {\n const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n const merged = new Uint8Array(totalLength);\n let offset = 0;\n for (const buffer of buffers) {\n merged.set(buffer, offset);\n offset += buffer.length;\n }\n\n return merged;\n}\n\n/**\n * Parses an envelope\n */\nfunction parseEnvelope(env) {\n let buffer = typeof env === 'string' ? encodeUTF8(env) : env;\n\n function readBinary(length) {\n const bin = buffer.subarray(0, length);\n // Replace the buffer with the remaining data excluding trailing newline\n buffer = buffer.subarray(length + 1);\n return bin;\n }\n\n function readJson() {\n let i = buffer.indexOf(0xa);\n // If we couldn't find a newline, we must have found the end of the buffer\n if (i < 0) {\n i = buffer.length;\n }\n\n return JSON.parse(decodeUTF8(readBinary(i))) ;\n }\n\n const envelopeHeader = readJson();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const items = [];\n\n while (buffer.length) {\n const itemHeader = readJson();\n const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n }\n\n return [envelopeHeader, items];\n}\n\n/**\n * Creates envelope item for a single span\n */\nfunction createSpanEnvelopeItem(spanJson) {\n const spanHeaders = {\n type: 'span',\n };\n\n return [spanHeaders, spanJson];\n}\n\n/**\n * Creates attachment envelope items\n */\nfunction createAttachmentEnvelopeItem(attachment) {\n const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data) : attachment.data;\n\n return [\n {\n type: 'attachment',\n length: buffer.length,\n filename: attachment.filename,\n content_type: attachment.contentType,\n attachment_type: attachment.attachmentType,\n },\n buffer,\n ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP = {\n session: 'session',\n sessions: 'session',\n attachment: 'attachment',\n transaction: 'transaction',\n event: 'error',\n client_report: 'internal',\n user_report: 'default',\n profile: 'profile',\n profile_chunk: 'profile',\n replay_event: 'replay',\n replay_recording: 'replay',\n check_in: 'monitor',\n feedback: 'feedback',\n span: 'span',\n raw_security: 'security',\n log: 'log_item',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nfunction envelopeItemTypeToDataCategory(type) {\n return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from the metadata or an events */\nfunction getSdkMetadataForEnvelopeHeader(metadataOrEvent) {\n if (!metadataOrEvent?.sdk) {\n return;\n }\n const { name, version } = metadataOrEvent.sdk;\n return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nfunction createEventEnvelopeHeaders(\n event,\n sdkInfo,\n tunnel,\n dsn,\n) {\n const dynamicSamplingContext = event.sdkProcessingMetadata?.dynamicSamplingContext;\n return {\n event_id: event.event_id ,\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n ...(dynamicSamplingContext && {\n trace: dynamicSamplingContext,\n }),\n };\n}\n\nexport { addItemToEnvelope, createAttachmentEnvelopeItem, createEnvelope, createEventEnvelopeHeaders, createSpanEnvelopeItem, envelopeContainsItemType, envelopeItemTypeToDataCategory, forEachEnvelopeItem, getSdkMetadataForEnvelopeHeader, parseEnvelope, serializeEnvelope };\n//# sourceMappingURL=envelope.js.map\n","import { isThenable } from './is.js';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/** SyncPromise internal states */\nconst STATE_PENDING = 0;\nconst STATE_RESOLVED = 1;\nconst STATE_REJECTED = 2;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nfunction resolvedSyncPromise(value) {\n return new SyncPromise(resolve => {\n resolve(value);\n });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nfunction rejectedSyncPromise(reason) {\n return new SyncPromise((_, reject) => {\n reject(reason);\n });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise {\n\n constructor(executor) {\n this._state = STATE_PENDING;\n this._handlers = [];\n\n this._runExecutor(executor);\n }\n\n /** @inheritdoc */\n then(\n onfulfilled,\n onrejected,\n ) {\n return new SyncPromise((resolve, reject) => {\n this._handlers.push([\n false,\n result => {\n if (!onfulfilled) {\n // TODO: ¯\\_(ツ)_/¯\n // TODO: FIXME\n resolve(result );\n } else {\n try {\n resolve(onfulfilled(result));\n } catch (e) {\n reject(e);\n }\n }\n },\n reason => {\n if (!onrejected) {\n reject(reason);\n } else {\n try {\n resolve(onrejected(reason));\n } catch (e) {\n reject(e);\n }\n }\n },\n ]);\n this._executeHandlers();\n });\n }\n\n /** @inheritdoc */\n catch(\n onrejected,\n ) {\n return this.then(val => val, onrejected);\n }\n\n /** @inheritdoc */\n finally(onfinally) {\n return new SyncPromise((resolve, reject) => {\n let val;\n let isRejected;\n\n return this.then(\n value => {\n isRejected = false;\n val = value;\n if (onfinally) {\n onfinally();\n }\n },\n reason => {\n isRejected = true;\n val = reason;\n if (onfinally) {\n onfinally();\n }\n },\n ).then(() => {\n if (isRejected) {\n reject(val);\n return;\n }\n\n resolve(val );\n });\n });\n }\n\n /** Excute the resolve/reject handlers. */\n _executeHandlers() {\n if (this._state === STATE_PENDING) {\n return;\n }\n\n const cachedHandlers = this._handlers.slice();\n this._handlers = [];\n\n cachedHandlers.forEach(handler => {\n if (handler[0]) {\n return;\n }\n\n if (this._state === STATE_RESOLVED) {\n handler[1](this._value );\n }\n\n if (this._state === STATE_REJECTED) {\n handler[2](this._value);\n }\n\n handler[0] = true;\n });\n }\n\n /** Run the executor for the SyncPromise. */\n _runExecutor(executor) {\n const setResult = (state, value) => {\n if (this._state !== STATE_PENDING) {\n return;\n }\n\n if (isThenable(value)) {\n void (value ).then(resolve, reject);\n return;\n }\n\n this._state = state;\n this._value = value;\n\n this._executeHandlers();\n };\n\n const resolve = (value) => {\n setResult(STATE_RESOLVED, value);\n };\n\n const reject = (reason) => {\n setResult(STATE_REJECTED, reason);\n };\n\n try {\n executor(resolve, reject);\n } catch (e) {\n reject(e);\n }\n }\n}\n\nexport { SyncPromise, rejectedSyncPromise, resolvedSyncPromise };\n//# sourceMappingURL=syncpromise.js.map\n","import { SyncPromise, resolvedSyncPromise, rejectedSyncPromise } from './syncpromise.js';\n\nconst SENTRY_BUFFER_FULL_ERROR = Symbol.for('SentryBufferFullError');\n\n/**\n * Creates an new PromiseBuffer object with the specified limit\n * @param limit max number of promises that can be stored in the buffer\n */\nfunction makePromiseBuffer(limit) {\n const buffer = [];\n\n function isReady() {\n return limit === undefined || buffer.length < limit;\n }\n\n /**\n * Remove a promise from the queue.\n *\n * @param task Can be any PromiseLike\n * @returns Removed promise.\n */\n function remove(task) {\n return buffer.splice(buffer.indexOf(task), 1)[0] || Promise.resolve(undefined);\n }\n\n /**\n * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment.\n *\n * @param taskProducer A function producing any PromiseLike; In previous versions this used to be `task:\n * PromiseLike`, but under that model, Promises were instantly created on the call-site and their executor\n * functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By\n * requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer\n * limit check.\n * @returns The original promise.\n */\n function add(taskProducer) {\n if (!isReady()) {\n return rejectedSyncPromise(SENTRY_BUFFER_FULL_ERROR);\n }\n\n // start the task and add its promise to the queue\n const task = taskProducer();\n if (buffer.indexOf(task) === -1) {\n buffer.push(task);\n }\n void task\n .then(() => remove(task))\n // Use `then(null, rejectionHandler)` rather than `catch(rejectionHandler)` so that we can use `PromiseLike`\n // rather than `Promise`. `PromiseLike` doesn't have a `.catch` method, making its polyfill smaller. (ES5 didn't\n // have promises, so TS has to polyfill when down-compiling.)\n .then(null, () =>\n remove(task).then(null, () => {\n // We have to add another catch here because `remove()` starts a new promise chain.\n }),\n );\n return task;\n }\n\n /**\n * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or\n * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and\n * `false` otherwise\n */\n function drain(timeout) {\n return new SyncPromise((resolve, reject) => {\n let counter = buffer.length;\n\n if (!counter) {\n return resolve(true);\n }\n\n // wait for `timeout` ms and then resolve to `false` (if not cancelled first)\n const capturedSetTimeout = setTimeout(() => {\n if (timeout && timeout > 0) {\n resolve(false);\n }\n }, timeout);\n\n // if all promises resolve in time, cancel the timer and resolve to `true`\n buffer.forEach(item => {\n void resolvedSyncPromise(item).then(() => {\n if (!--counter) {\n clearTimeout(capturedSetTimeout);\n resolve(true);\n }\n }, reject);\n });\n });\n }\n\n return {\n $: buffer,\n add,\n drain,\n };\n}\n\nexport { SENTRY_BUFFER_FULL_ERROR, makePromiseBuffer };\n//# sourceMappingURL=promisebuffer.js.map\n","// Intentionally keeping the key broad, as we don't know for sure what rate limit headers get returned from backend\n\nconst DEFAULT_RETRY_AFTER = 60 * 1000; // 60 seconds\n\n/**\n * Extracts Retry-After value from the request header or returns default value\n * @param header string representation of 'Retry-After' header\n * @param now current unix timestamp\n *\n */\nfunction parseRetryAfterHeader(header, now = Date.now()) {\n const headerDelay = parseInt(`${header}`, 10);\n if (!isNaN(headerDelay)) {\n return headerDelay * 1000;\n }\n\n const headerDate = Date.parse(`${header}`);\n if (!isNaN(headerDate)) {\n return headerDate - now;\n }\n\n return DEFAULT_RETRY_AFTER;\n}\n\n/**\n * Gets the time that the given category is disabled until for rate limiting.\n * In case no category-specific limit is set but a general rate limit across all categories is active,\n * that time is returned.\n *\n * @return the time in ms that the category is disabled until or 0 if there's no active rate limit.\n */\nfunction disabledUntil(limits, dataCategory) {\n return limits[dataCategory] || limits.all || 0;\n}\n\n/**\n * Checks if a category is rate limited\n */\nfunction isRateLimited(limits, dataCategory, now = Date.now()) {\n return disabledUntil(limits, dataCategory) > now;\n}\n\n/**\n * Update ratelimits from incoming headers.\n *\n * @return the updated RateLimits object.\n */\nfunction updateRateLimits(\n limits,\n { statusCode, headers },\n now = Date.now(),\n) {\n const updatedRateLimits = {\n ...limits,\n };\n\n // \"The name is case-insensitive.\"\n // https://developer.mozilla.org/en-US/docs/Web/API/Headers/get\n const rateLimitHeader = headers?.['x-sentry-rate-limits'];\n const retryAfterHeader = headers?.['retry-after'];\n\n if (rateLimitHeader) {\n /**\n * rate limit headers are of the form\n *
,
,..\n * where each
is of the form\n * : : : : \n * where\n * is a delay in seconds\n * is the event type(s) (error, transaction, etc) being rate limited and is of the form\n * ;;...\n * is what's being limited (org, project, or key) - ignored by SDK\n * is an arbitrary string like \"org_quota\" - ignored by SDK\n * Semicolon-separated list of metric namespace identifiers. Defines which namespace(s) will be affected.\n * Only present if rate limit applies to the metric_bucket data category.\n */\n for (const limit of rateLimitHeader.trim().split(',')) {\n const [retryAfter, categories, , , namespaces] = limit.split(':', 5) ;\n const headerDelay = parseInt(retryAfter, 10);\n const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1000; // 60sec default\n if (!categories) {\n updatedRateLimits.all = now + delay;\n } else {\n for (const category of categories.split(';')) {\n if (category === 'metric_bucket') {\n // namespaces will be present when category === 'metric_bucket'\n if (!namespaces || namespaces.split(';').includes('custom')) {\n updatedRateLimits[category] = now + delay;\n }\n } else {\n updatedRateLimits[category] = now + delay;\n }\n }\n }\n }\n } else if (retryAfterHeader) {\n updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now);\n } else if (statusCode === 429) {\n updatedRateLimits.all = now + 60 * 1000;\n }\n\n return updatedRateLimits;\n}\n\nexport { DEFAULT_RETRY_AFTER, disabledUntil, isRateLimited, parseRetryAfterHeader, updateRateLimits };\n//# sourceMappingURL=ratelimit.js.map\n","import { DEBUG_BUILD } from '../debug-build.js';\nimport { debug } from '../utils/debug-logger.js';\nimport { forEachEnvelopeItem, envelopeItemTypeToDataCategory, createEnvelope, serializeEnvelope } from '../utils/envelope.js';\nimport { makePromiseBuffer, SENTRY_BUFFER_FULL_ERROR } from '../utils/promisebuffer.js';\nimport { isRateLimited, updateRateLimits } from '../utils/ratelimit.js';\nimport { resolvedSyncPromise } from '../utils/syncpromise.js';\n\nconst DEFAULT_TRANSPORT_BUFFER_SIZE = 64;\n\n/**\n * Creates an instance of a Sentry `Transport`\n *\n * @param options\n * @param makeRequest\n */\nfunction createTransport(\n options,\n makeRequest,\n buffer = makePromiseBuffer(\n options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,\n ),\n) {\n let rateLimits = {};\n const flush = (timeout) => buffer.drain(timeout);\n\n function send(envelope) {\n const filteredEnvelopeItems = [];\n\n // Drop rate limited items from envelope\n forEachEnvelopeItem(envelope, (item, type) => {\n const dataCategory = envelopeItemTypeToDataCategory(type);\n if (isRateLimited(rateLimits, dataCategory)) {\n options.recordDroppedEvent('ratelimit_backoff', dataCategory);\n } else {\n filteredEnvelopeItems.push(item);\n }\n });\n\n // Skip sending if envelope is empty after filtering out rate limited events\n if (filteredEnvelopeItems.length === 0) {\n return resolvedSyncPromise({});\n }\n\n const filteredEnvelope = createEnvelope(envelope[0], filteredEnvelopeItems );\n\n // Creates client report for each item in an envelope\n const recordEnvelopeLoss = (reason) => {\n forEachEnvelopeItem(filteredEnvelope, (item, type) => {\n options.recordDroppedEvent(reason, envelopeItemTypeToDataCategory(type));\n });\n };\n\n const requestTask = () =>\n makeRequest({ body: serializeEnvelope(filteredEnvelope) }).then(\n response => {\n // We don't want to throw on NOK responses, but we want to at least log them\n if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {\n DEBUG_BUILD && debug.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);\n }\n\n rateLimits = updateRateLimits(rateLimits, response);\n return response;\n },\n error => {\n recordEnvelopeLoss('network_error');\n DEBUG_BUILD && debug.error('Encountered error running transport request:', error);\n throw error;\n },\n );\n\n return buffer.add(requestTask).then(\n result => result,\n error => {\n if (error === SENTRY_BUFFER_FULL_ERROR) {\n DEBUG_BUILD && debug.error('Skipped sending event because buffer is full.');\n recordEnvelopeLoss('queue_overflow');\n return resolvedSyncPromise({});\n } else {\n throw error;\n }\n },\n );\n }\n\n return {\n send,\n flush,\n };\n}\n\nexport { DEFAULT_TRANSPORT_BUFFER_SIZE, createTransport };\n//# sourceMappingURL=base.js.map\n","/**\n * Initialise GlitchTip.\n */\n\nimport type { Transport, TransportMakeRequestResponse, TransportRequest } from \"@sentry/core\";\n\nimport { pipe } from \"@mobily/ts-belt\";\nimport {\n breadcrumbsIntegration,\n browserApiErrorsIntegration,\n BrowserClient,\n captureConsoleIntegration,\n dedupeIntegration,\n defaultStackParser,\n functionToStringIntegration,\n getCurrentScope,\n globalHandlersIntegration,\n httpClientIntegration,\n httpContextIntegration,\n linkedErrorsIntegration,\n} from \"@sentry/browser\";\nimport { createTransport } from \"@sentry/core\";\n\nimport { ENTETE_GLITCHTIP_RATE_LIMITS, ENTETE_GLITCHTIP_RETRY_AFTER } from \"./constantes/api\";\n\n/* Créé la fonction génératrice de la requête auprès de GlitchTip */\nconst creeTransportFetch = (options): Transport => {\n const creeRequete = async (requete: TransportRequest): Promise => {\n const optionsRequete: RequestInit = {\n body: requete.body,\n headers: options.headers ?? {},\n method: \"POST\",\n mode: \"no-cors\",\n referrerPolicy: \"no-referrer\",\n ...options.fetchOptions,\n };\n\n return pipe(\n await fetch(options.url, optionsRequete),\n (reponse: Response) => ({\n headers: {\n [ENTETE_GLITCHTIP_RATE_LIMITS]: reponse.headers.get(ENTETE_GLITCHTIP_RATE_LIMITS),\n [ENTETE_GLITCHTIP_RETRY_AFTER]: reponse.headers.get(ENTETE_GLITCHTIP_RETRY_AFTER),\n },\n statusCode: reponse.status,\n }),\n );\n };\n\n return createTransport(options, creeRequete);\n};\n\n/* Créé la configuration Sentry */\nconst client = new BrowserClient({\n dsn: import.meta.env.VITE_GLITCHTIP_NSD,\n environment: import.meta.env.VITE_MODE,\n integrations: [\n // Wraps native browser APIs to capture breadcrumbs.\n breadcrumbsIntegration(),\n // Wraps native time and events APIs in `try/catch` blocks to handle async exceptions\n browserApiErrorsIntegration(),\n // Captures all Console API calls via `captureException` or `captureMessage`.\n captureConsoleIntegration({ levels: [\"warn\", \"error\"] }),\n // Deduplicate certain events to avoid receiving duplicate errors.\n dedupeIntegration(),\n // Allows the SDK to provide original functions and method names, even when those functions or methods are wrapped by our error or breadcrumb handlers.\n functionToStringIntegration(),\n // Attaches global handlers to capture uncaught exceptions and unhandled rejections.\n globalHandlersIntegration(),\n // Captures errors on failed requests from Fetch and XHR and attaches request and response information.\n httpClientIntegration({\n failedRequestStatusCodes: [[400, 599]],\n }),\n // Attaches HTTP request information, such as URL, user-agent, referrer, and other headers to the event.\n httpContextIntegration(),\n // Allows you to configure linked errors.\n linkedErrorsIntegration(),\n ],\n sendDefaultPii: true,\n stackParser: defaultStackParser,\n tracesSampleRate: 1,\n transport: creeTransportFetch,\n});\n\n/* Initialise la configuration */\ngetCurrentScope().setClient(client);\nclient.init();\n"],"x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js b/web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js new file mode 100644 index 00000000..41860437 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js @@ -0,0 +1,276 @@ +import { Cn as mapU, On as equal, Sn as forEachU, bn as values, fn as append, gn as get$1, hn as fromArray, wn as reduceU, yn as unsafeDeleteKey } from "./dom.emspS_OW.js"; + +//#region node_modules/@mobily/ts-belt/dist/index-514c1a6c.mjs +function placeholder(e) {} +function makeEmpty(e) { + return {}; +} +function _getUnsafe(e, t) { + return e[t]; +} +function getUnsafe() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _getUnsafe(t, e[0]); + }; + } + return _getUnsafe(arguments[0], arguments[1]); +} +var o = get$1; +function get() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return o(t, e[0]); + }; + } + return o(arguments[0], arguments[1]); +} +function _prop(e, t) { + return e[t]; +} +function prop() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _prop(t, e[0]); + }; + } + return _prop(arguments[0], arguments[1]); +} +function toPairs(e) { + return Object.entries(e); +} +var a = values; +function keys(e) { + return Object.keys(e); +} +var l = fromArray; +function _merge(e, t) { + return Object.assign({}, e, t); +} +function merge() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _merge(t, e[0]); + }; + } + return _merge(arguments[0], arguments[1]); +} +function _set(e, t, n) { + var r = merge({}, e); + r[t] = n; + return r; +} +function set() { + if (2 === arguments.length) { + const e = arguments; + return function fn(t) { + return _set(t, e[0], e[1]); + }; + } + return _set(arguments[0], arguments[1], arguments[2]); +} +function _update(e, t, r) { + return set(e, t, r(get$1(e, t))); +} +function update() { + if (2 === arguments.length) { + const e = arguments; + return function fn(t) { + return _update(t, e[0], e[1]); + }; + } + return _update(arguments[0], arguments[1], arguments[2]); +} +function _updateUnsafe(e, t, n) { + return set(e, t, n(e[t])); +} +function updateUnsafe() { + if (2 === arguments.length) { + const e = arguments; + return function fn(t) { + return _updateUnsafe(t, e[0], e[1]); + }; + } + return _updateUnsafe(arguments[0], arguments[1], arguments[2]); +} +function _deleteKey(e, t) { + var n = merge({}, e); + unsafeDeleteKey(n, t); + return n; +} +function deleteKey() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _deleteKey(t, e[0]); + }; + } + return _deleteKey(arguments[0], arguments[1]); +} +function _deleteKeys(e, t) { + var n = merge({}, e); + forEachU(t, (function(e$1) { + unsafeDeleteKey(n, e$1); + })); + return n; +} +function deleteKeys() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _deleteKeys(t, e[0]); + }; + } + return _deleteKeys(arguments[0], arguments[1]); +} +function _map(e, n) { + return fromArray(mapU(Object.keys(e), (function(t) { + return [t, n(e[t])]; + }))); +} +function map() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _map(t, e[0]); + }; + } + return _map(arguments[0], arguments[1]); +} +function _mapWithKey(e, n) { + return fromArray(mapU(Object.keys(e), (function(t) { + return [t, n(t, e[t])]; + }))); +} +function mapWithKey() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _mapWithKey(t, e[0]); + }; + } + return _mapWithKey(arguments[0], arguments[1]); +} +function _filter(e, n) { + return fromArray(reduceU(Object.keys(e), [], (function(t, r) { + var i = e[r]; + if (n(i)) return append(t, [r, i]); + else return t; + }))); +} +function filter() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _filter(t, e[0]); + }; + } + return _filter(arguments[0], arguments[1]); +} +function _filterWithKey(e, n) { + return fromArray(reduceU(Object.keys(e), [], (function(t, r) { + var i = e[r]; + if (n(r, i)) return append(t, [r, i]); + else return t; + }))); +} +function filterWithKey() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _filterWithKey(t, e[0]); + }; + } + return _filterWithKey(arguments[0], arguments[1]); +} +function _reject(e, t) { + return filter(e, (function(e$1) { + return !t(e$1); + })); +} +function reject() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _reject(t, e[0]); + }; + } + return _reject(arguments[0], arguments[1]); +} +function _rejectWithKey(e, t) { + return filterWithKey(e, (function(e$1, n) { + return !t(e$1, n); + })); +} +function rejectWithKey() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _rejectWithKey(t, e[0]); + }; + } + return _rejectWithKey(arguments[0], arguments[1]); +} +function _selectKeys(e, t) { + return filterWithKey(e, (function(e$1, n) { + return function includes(e$2, t$1) { + return t$1.includes(e$2); + }(e$1, t); + })); +} +function selectKeys() { + if (1 === arguments.length) { + const e = arguments; + return function fn(t) { + return _selectKeys(t, e[0]); + }; + } + return _selectKeys(arguments[0], arguments[1]); +} +function isEmpty(e) { + return equal(e, {}); +} +function isNotEmpty(e) { + return !equal(e, {}); +} +var y = { + __proto__: null, + placeholder, + makeEmpty, + getUnsafe, + get, + prop, + toPairs, + values: a, + keys, + fromPairs: l, + merge, + set, + update, + updateUnsafe, + deleteKey, + deleteKeys, + map, + mapWithKey, + filter, + filterWithKey, + reject, + rejectWithKey, + selectKeys, + isEmpty, + isNotEmpty +}; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/gardes.ts +var estElement = (typeElement) => (element) => element instanceof typeElement; +const estHTMLSelectElement = estElement(HTMLSelectElement); +const estReponse500 = (reponse) => reponse.status === 500; + +//#endregion +export { map as a, get as i, estReponse500 as n, y as o, a as r, estHTMLSelectElement as t }; +//# sourceMappingURL=gardes.CYxPzOAc.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js.map b/web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js.map new file mode 100644 index 00000000..1b8d8805 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/gardes.CYxPzOAc.js.map @@ -0,0 +1 @@ +{"version":3,"file":"gardes.CYxPzOAc.js","names":["n","e","t","s","c","u","i"],"sources":["../../../../../../node_modules/@mobily/ts-belt/dist/index-514c1a6c.mjs","../../src/scripts/lib/gardes.ts"],"sourcesContent":["import { aD as e, aE as t, aF as n, aG as r, e as u } from \"./Array.bs-4b4ec77c.mjs\";\n\nimport { e as i } from \"./caml_obj-c29533cc.mjs\";\n\nimport { f, b as s, r as c } from \"./belt_Array-b9ebcaa6.mjs\";\n\nfunction placeholder(e) {}\n\nfunction makeEmpty(e) {\n return {};\n}\n\nfunction _getUnsafe(e, t) {\n return e[t];\n}\n\nfunction getUnsafe() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _getUnsafe(t, e[0]);\n };\n }\n return _getUnsafe(arguments[0], arguments[1]);\n}\n\nvar o = n;\n\nfunction get() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return o(t, e[0]);\n };\n }\n return o(arguments[0], arguments[1]);\n}\n\nfunction _prop(e, t) {\n return e[t];\n}\n\nfunction prop() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _prop(t, e[0]);\n };\n }\n return _prop(arguments[0], arguments[1]);\n}\n\nfunction toPairs(e) {\n return Object.entries(e);\n}\n\nvar a = e;\n\nfunction keys(e) {\n return Object.keys(e);\n}\n\nvar l = t;\n\nfunction _merge(e, t) {\n return Object.assign({}, e, t);\n}\n\nfunction merge() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _merge(t, e[0]);\n };\n }\n return _merge(arguments[0], arguments[1]);\n}\n\nfunction _set(e, t, n) {\n var r = merge({}, e);\n r[t] = n;\n return r;\n}\n\nfunction set() {\n if (2 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _set(t, e[0], e[1]);\n };\n }\n return _set(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _update(e, t, r) {\n return set(e, t, r(n(e, t)));\n}\n\nfunction update() {\n if (2 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _update(t, e[0], e[1]);\n };\n }\n return _update(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _updateUnsafe(e, t, n) {\n return set(e, t, n(e[t]));\n}\n\nfunction updateUnsafe() {\n if (2 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _updateUnsafe(t, e[0], e[1]);\n };\n }\n return _updateUnsafe(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _deleteKey(e, t) {\n var n = merge({}, e);\n r(n, t);\n return n;\n}\n\nfunction deleteKey() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _deleteKey(t, e[0]);\n };\n }\n return _deleteKey(arguments[0], arguments[1]);\n}\n\nfunction _deleteKeys(e, t) {\n var n = merge({}, e);\n f(t, (function(e) {\n r(n, e);\n }));\n return n;\n}\n\nfunction deleteKeys() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _deleteKeys(t, e[0]);\n };\n }\n return _deleteKeys(arguments[0], arguments[1]);\n}\n\nfunction _map(e, n) {\n return t(s(Object.keys(e), (function(t) {\n return [ t, n(e[t]) ];\n })));\n}\n\nfunction map() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _map(t, e[0]);\n };\n }\n return _map(arguments[0], arguments[1]);\n}\n\nfunction _mapWithKey(e, n) {\n return t(s(Object.keys(e), (function(t) {\n return [ t, n(t, e[t]) ];\n })));\n}\n\nfunction mapWithKey() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _mapWithKey(t, e[0]);\n };\n }\n return _mapWithKey(arguments[0], arguments[1]);\n}\n\nfunction _filter(e, n) {\n return t(c(Object.keys(e), [], (function(t, r) {\n var i = e[r];\n if (n(i)) {\n return u(t, [ r, i ]);\n } else {\n return t;\n }\n })));\n}\n\nfunction filter() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _filter(t, e[0]);\n };\n }\n return _filter(arguments[0], arguments[1]);\n}\n\nfunction _filterWithKey(e, n) {\n return t(c(Object.keys(e), [], (function(t, r) {\n var i = e[r];\n if (n(r, i)) {\n return u(t, [ r, i ]);\n } else {\n return t;\n }\n })));\n}\n\nfunction filterWithKey() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _filterWithKey(t, e[0]);\n };\n }\n return _filterWithKey(arguments[0], arguments[1]);\n}\n\nfunction _reject(e, t) {\n return filter(e, (function(e) {\n return !t(e);\n }));\n}\n\nfunction reject() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _reject(t, e[0]);\n };\n }\n return _reject(arguments[0], arguments[1]);\n}\n\nfunction _rejectWithKey(e, t) {\n return filterWithKey(e, (function(e, n) {\n return !t(e, n);\n }));\n}\n\nfunction rejectWithKey() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _rejectWithKey(t, e[0]);\n };\n }\n return _rejectWithKey(arguments[0], arguments[1]);\n}\n\nfunction _selectKeys(e, t) {\n return filterWithKey(e, (function(e, n) {\n return function includes(e, t) {\n return t.includes(e);\n }(e, t);\n }));\n}\n\nfunction selectKeys() {\n if (1 === arguments.length) {\n const e = arguments;\n return function fn(t) {\n return _selectKeys(t, e[0]);\n };\n }\n return _selectKeys(arguments[0], arguments[1]);\n}\n\nfunction isEmpty(e) {\n return i(e, {});\n}\n\nfunction isNotEmpty(e) {\n return !i(e, {});\n}\n\nvar y = {\n __proto__: null,\n placeholder,\n makeEmpty,\n getUnsafe,\n get,\n prop,\n toPairs,\n values: a,\n keys,\n fromPairs: l,\n merge,\n set,\n update,\n updateUnsafe,\n deleteKey,\n deleteKeys,\n map,\n mapWithKey,\n filter,\n filterWithKey,\n reject,\n rejectWithKey,\n selectKeys,\n isEmpty,\n isNotEmpty\n};\n\nexport { get as a, prop as b, merge as c, updateUnsafe as d, deleteKey as e, l as f, getUnsafe as g, deleteKeys as h, y as i, map as j, keys as k, mapWithKey as l, makeEmpty as m, filter as n, filterWithKey as o, placeholder as p, rejectWithKey as q, reject as r, set as s, toPairs as t, update as u, a as v, selectKeys as w, isEmpty as x, isNotEmpty as y };\n","import type { Constructor } from \"./types/classes\";\n\nconst estElement = (typeElement: Constructor) => (element: unknown): element is T =>\n element instanceof typeElement;\n\nexport const estHTMLSelectElement = estElement(HTMLSelectElement);\n\nexport const estError = (erreur: unknown): erreur is Error => erreur instanceof Error;\n\nexport const estReponse500 = (reponse: Response): boolean => reponse.status === 500;\n"],"x_google_ignoreList":[0],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js b/web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js new file mode 100644 index 00000000..60d4a948 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js @@ -0,0 +1,273 @@ +import { Dn as valFromOption, En as some, On as equal, Tn as nullable_to_opt, wn as reduceU, xn as concat } from "./dom.emspS_OW.js"; +import { a as isNone, c as mapWithDefaultU, d as is_extension, i as getWithDefault, l as _1, n as flatMapU, o as isSome, r as getExn, s as mapU, t as flatMap, u as create } from "./belt_Option-91f3b350.CMbgtZ-W.js"; + +//#region node_modules/@mobily/ts-belt/dist/Promise.bs-06a7bae6.mjs +var t = create("Promise.JsError"); +function $$catch(r, s) { + return r.catch((function(r$1) { + return _1(s, is_extension(r$1) ? r$1 : { + RE_EXN_ID: t, + _1: r$1 + }); + })); +} + +//#endregion +//#region node_modules/@mobily/ts-belt/dist/index-c1cc4c86.mjs +function placeholder(n) {} +function makeSome(n) { + return some(n); +} +function makeNone(n) {} +function fromNullable(n) { + if (null == n) return; + else return some(n); +} +function fromFalsy(n) { + if (n) return n; +} +function _fromPredicate(n, t$1) { + return flatMap(null == n ? void 0 : some(n), (function(n$1) { + if (t$1(n$1)) return some(n$1); + })); +} +function fromPredicate() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _fromPredicate(t$1, n[0]); + }; + } + return _fromPredicate(arguments[0], arguments[1]); +} +function fromExecution(n) { + try { + return some(n(void 0)); + } catch (n$1) { + return; + } +} +function fromPromise(t$1) { + return $$catch(t$1.then((function(n) { + return some(n); + })), (function(n) { + return Promise.resolve(void 0); + })); +} +var h = mapU; +function map() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return h(t$1, n[0]); + }; + } + return h(arguments[0], arguments[1]); +} +var _ = flatMapU; +function flatMap$1() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _(t$1, n[0]); + }; + } + return _(arguments[0], arguments[1]); +} +var v = mapWithDefaultU; +function mapWithDefault() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return v(t$1, n[0], n[1]); + }; + } + return v(arguments[0], arguments[1], arguments[2]); +} +function _mapNullable(n, t$1) { + if (void 0 !== n) return nullable_to_opt(t$1(valFromOption(n))); +} +function mapNullable() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _mapNullable(t$1, n[0]); + }; + } + return _mapNullable(arguments[0], arguments[1]); +} +function _filter(n, t$1) { + return flatMapU(n, (function(n$1) { + if (t$1(n$1)) return some(n$1); + })); +} +function filter() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _filter(t$1, n[0]); + }; + } + return _filter(arguments[0], arguments[1]); +} +var g = getWithDefault; +function getWithDefault$1() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return g(t$1, n[0]); + }; + } + return g(arguments[0], arguments[1]); +} +var N = getExn; +function toNullable(n) { + return getWithDefault(n, null); +} +function toUndefined(n) { + return getWithDefault(n, void 0); +} +function _toResult(n, t$1) { + if (void 0 !== n) return { + TAG: 0, + _0: valFromOption(n) + }; + else return { + TAG: 1, + _0: t$1 + }; +} +function toResult() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _toResult(t$1, n[0]); + }; + } + return _toResult(arguments[0], arguments[1]); +} +function _match(n, t$1, r) { + if (void 0 !== n) return t$1(valFromOption(n)); + else return r(void 0); +} +function match() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _match(t$1, n[0], n[1]); + }; + } + return _match(arguments[0], arguments[1], arguments[2]); +} +var b = isNone; +var z = isSome; +function _tap(n, t$1) { + if (void 0 !== n) { + t$1(valFromOption(n)); + return n; + } else return n; +} +function tap() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _tap(t$1, n[0]); + }; + } + return _tap(arguments[0], arguments[1]); +} +function _contains(n, r) { + return mapWithDefaultU(n, !1, (function(n$1) { + return equal(n$1, r); + })); +} +function contains() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _contains(t$1, n[0]); + }; + } + return _contains(arguments[0], arguments[1]); +} +function _zip(n, t$1) { + if (void 0 !== n && void 0 !== t$1) return [valFromOption(n), valFromOption(t$1)]; +} +function zip() { + if (1 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _zip(t$1, n[0]); + }; + } + return _zip(arguments[0], arguments[1]); +} +function _zipWith(n, t$1, r) { + if (void 0 !== n && void 0 !== t$1) return some(r(valFromOption(n), valFromOption(t$1))); +} +function zipWith() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _zipWith(t$1, n[0], n[1]); + }; + } + return _zipWith(arguments[0], arguments[1], arguments[2]); +} +function _fold(n, t$1, r) { + if (void 0 !== n) return t$1(valFromOption(n)); + else return r(void 0); +} +function fold() { + if (2 === arguments.length) { + const n = arguments; + return function fn(t$1) { + return _fold(t$1, n[0], n[1]); + }; + } + return _fold(arguments[0], arguments[1], arguments[2]); +} +function all(n) { + return reduceU(n, [], (function(n$1, t$1) { + return flatMapU(n$1, (function(n$2) { + if (void 0 !== t$1) return concat(n$2, [valFromOption(t$1)]); + })); + })); +} +var Some = (n) => n; +var P = { + __proto__: null, + Some, + None: void 0, + placeholder, + makeSome, + makeNone, + fromNullable, + fromFalsy, + fromPredicate, + fromExecution, + fromPromise, + map, + flatMap: flatMap$1, + mapWithDefault, + mapNullable, + filter, + getWithDefault: getWithDefault$1, + getExn: N, + toNullable, + toUndefined, + toResult, + match, + isNone: b, + isSome: z, + tap, + contains, + zip, + zipWith, + fold, + all +}; + +//#endregion +export { tap as n, P as t }; +//# sourceMappingURL=index-c1cc4c86.D2nZEikK.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js.map b/web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js.map new file mode 100644 index 00000000..27e8bb62 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/index-c1cc4c86.D2nZEikK.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index-c1cc4c86.D2nZEikK.js","names":["r","a","c","m","a","t","n","l","c","flatMap","s","p","d","i","getWithDefault","o","u","f","r","e"],"sources":["../../../../../../node_modules/@mobily/ts-belt/dist/Promise.bs-06a7bae6.mjs","../../../../../../node_modules/@mobily/ts-belt/dist/index-c1cc4c86.mjs"],"sourcesContent":["import { c as r, a, i as c } from \"./caml_exceptions-99f2c2ac.mjs\";\n\nvar t = r(\"Promise.JsError\");\n\nfunction $$catch(r, s) {\n return r.catch((function(r) {\n return a(s, c(r) ? r : {\n RE_EXN_ID: t,\n _1: r\n });\n }));\n}\n\nexport { $$catch as $, t as J };\n","import { $ as n } from \"./Promise.bs-06a7bae6.mjs\";\n\nimport { e as t } from \"./caml_obj-c29533cc.mjs\";\n\nimport { r, c as e } from \"./belt_Array-b9ebcaa6.mjs\";\n\nimport { g as o, a as i, b as u, i as f, f as a, c as l, d as c, m as s } from \"./belt_Option-91f3b350.mjs\";\n\nimport { s as m, n as p, v as d } from \"./caml_option-16487d6d.mjs\";\n\nfunction placeholder(n) {}\n\nfunction makeSome(n) {\n return m(n);\n}\n\nfunction makeNone(n) {}\n\nfunction fromNullable(n) {\n if (null == n) {\n return;\n } else {\n return m(n);\n }\n}\n\nfunction fromFalsy(n) {\n if (n) {\n return n;\n }\n}\n\nfunction _fromPredicate(n, t) {\n return a(null == n ? void 0 : m(n), (function(n) {\n if (t(n)) {\n return m(n);\n }\n }));\n}\n\nfunction fromPredicate() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _fromPredicate(t, n[0]);\n };\n }\n return _fromPredicate(arguments[0], arguments[1]);\n}\n\nfunction fromExecution(n) {\n try {\n return m(n(void 0));\n } catch (n) {\n return;\n }\n}\n\nfunction fromPromise(t) {\n return n(t.then((function(n) {\n return m(n);\n })), (function(n) {\n return Promise.resolve(void 0);\n }));\n}\n\nvar h = l;\n\nfunction map() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return h(t, n[0]);\n };\n }\n return h(arguments[0], arguments[1]);\n}\n\nvar _ = c;\n\nfunction flatMap() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _(t, n[0]);\n };\n }\n return _(arguments[0], arguments[1]);\n}\n\nvar v = s;\n\nfunction mapWithDefault() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return v(t, n[0], n[1]);\n };\n }\n return v(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _mapNullable(n, t) {\n if (void 0 !== n) {\n return p(t(d(n)));\n }\n}\n\nfunction mapNullable() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _mapNullable(t, n[0]);\n };\n }\n return _mapNullable(arguments[0], arguments[1]);\n}\n\nfunction _filter(n, t) {\n return c(n, (function(n) {\n if (t(n)) {\n return m(n);\n }\n }));\n}\n\nfunction filter() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _filter(t, n[0]);\n };\n }\n return _filter(arguments[0], arguments[1]);\n}\n\nvar g = i;\n\nfunction getWithDefault() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return g(t, n[0]);\n };\n }\n return g(arguments[0], arguments[1]);\n}\n\nvar N = o;\n\nfunction toNullable(n) {\n return i(n, null);\n}\n\nfunction toUndefined(n) {\n return i(n, void 0);\n}\n\nfunction _toResult(n, t) {\n if (void 0 !== n) {\n return {\n TAG: 0,\n _0: d(n)\n };\n } else {\n return {\n TAG: 1,\n _0: t\n };\n }\n}\n\nfunction toResult() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _toResult(t, n[0]);\n };\n }\n return _toResult(arguments[0], arguments[1]);\n}\n\nfunction _match(n, t, r) {\n if (void 0 !== n) {\n return t(d(n));\n } else {\n return r(void 0);\n }\n}\n\nfunction match() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _match(t, n[0], n[1]);\n };\n }\n return _match(arguments[0], arguments[1], arguments[2]);\n}\n\nvar b = u;\n\nvar z = f;\n\nfunction _tap(n, t) {\n if (void 0 !== n) {\n t(d(n));\n return n;\n } else {\n return n;\n }\n}\n\nfunction tap() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _tap(t, n[0]);\n };\n }\n return _tap(arguments[0], arguments[1]);\n}\n\nfunction _contains(n, r) {\n return s(n, !1, (function(n) {\n return t(n, r);\n }));\n}\n\nfunction contains() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _contains(t, n[0]);\n };\n }\n return _contains(arguments[0], arguments[1]);\n}\n\nfunction _zip(n, t) {\n if (void 0 !== n && void 0 !== t) {\n return [ d(n), d(t) ];\n }\n}\n\nfunction zip() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _zip(t, n[0]);\n };\n }\n return _zip(arguments[0], arguments[1]);\n}\n\nfunction _zipWith(n, t, r) {\n if (void 0 !== n && void 0 !== t) {\n return m(r(d(n), d(t)));\n }\n}\n\nfunction zipWith() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _zipWith(t, n[0], n[1]);\n };\n }\n return _zipWith(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction _fold(n, t, r) {\n if (void 0 !== n) {\n return t(d(n));\n } else {\n return r(void 0);\n }\n}\n\nfunction fold() {\n if (2 === arguments.length) {\n const n = arguments;\n return function fn(t) {\n return _fold(t, n[0], n[1]);\n };\n }\n return _fold(arguments[0], arguments[1], arguments[2]);\n}\n\nfunction all(n) {\n return r(n, [], (function(n, t) {\n return c(n, (function(n) {\n if (void 0 !== t) {\n return e(n, [ d(t) ]);\n }\n }));\n }));\n}\n\nconst Some = n => n;\n\nconst W = void 0;\n\nvar P = {\n __proto__: null,\n Some,\n None: undefined,\n placeholder,\n makeSome,\n makeNone,\n fromNullable,\n fromFalsy,\n fromPredicate,\n fromExecution,\n fromPromise,\n map,\n flatMap,\n mapWithDefault,\n mapNullable,\n filter,\n getWithDefault,\n getExn: N,\n toNullable,\n toUndefined,\n toResult,\n match,\n isNone: b,\n isSome: z,\n tap,\n contains,\n zip,\n zipWith,\n fold,\n all\n};\n\nexport { fold as A, all as B, W as N, Some as S, makeNone as a, fromFalsy as b, fromPredicate as c, fromExecution as d, fromPromise as e, fromNullable as f, map as g, flatMap as h, P as i, mapWithDefault as j, mapNullable as k, filter as l, makeSome as m, getWithDefault as n, N as o, placeholder as p, toUndefined as q, toResult as r, match as s, toNullable as t, b as u, z as v, tap as w, contains as x, zipWith as y, zip as z };\n"],"x_google_ignoreList":[0,1],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js b/web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js new file mode 100644 index 00000000..d6451671 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js @@ -0,0 +1,1845 @@ +//#region rolldown:runtime +var __create = Object.create; +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __getOwnPropNames = Object.getOwnPropertyNames; +var __getProtoOf = Object.getPrototypeOf; +var __hasOwnProp = Object.prototype.hasOwnProperty; +var __commonJS = (cb, mod) => function() { + return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; +}; +var __export = (all) => { + let target = {}; + for (var name in all) __defProp(target, name, { + get: all[name], + enumerable: true + }); + return target; +}; +var __copyProps = (to, from, except, desc) => { + if (from && typeof from === "object" || typeof from === "function") for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) { + key = keys[i]; + if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { + get: ((k) => from[k]).bind(null, key), + enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable + }); + } + return to; +}; +var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { + value: mod, + enumerable: true +}) : target, mod)); + +//#endregion +//#region node_modules/@logtape/logtape/dist/filter.js +/** +* Converts a {@link FilterLike} value to an actual {@link Filter}. +* +* @param filter The filter-like value to convert. +* @returns The actual filter. +*/ +function toFilter(filter) { + if (typeof filter === "function") return filter; + return getLevelFilter(filter); +} +/** +* Returns a filter that accepts log records with the specified level. +* +* @param level The level to filter by. If `null`, the filter will reject all +* records. +* @returns The filter. +*/ +function getLevelFilter(level$1) { + if (level$1 == null) return () => false; + if (level$1 === "fatal") return (record) => record.level === "fatal"; + else if (level$1 === "error") return (record) => record.level === "fatal" || record.level === "error"; + else if (level$1 === "warning") return (record) => record.level === "fatal" || record.level === "error" || record.level === "warning"; + else if (level$1 === "info") return (record) => record.level === "fatal" || record.level === "error" || record.level === "warning" || record.level === "info"; + else if (level$1 === "debug") return (record) => record.level === "fatal" || record.level === "error" || record.level === "warning" || record.level === "info" || record.level === "debug"; + else if (level$1 === "trace") return () => true; + throw new TypeError(`Invalid log level: ${level$1}.`); +} + +//#endregion +//#region node_modules/@logtape/logtape/dist/level.js +var logLevels = [ + "trace", + "debug", + "info", + "warning", + "error", + "fatal" +]; +/** +* Compares two log levels. +* @param a The first log level. +* @param b The second log level. +* @returns A negative number if `a` is less than `b`, a positive number if `a` +* is greater than `b`, or zero if they are equal. +* @since 0.8.0 +*/ +function compareLogLevel(a, b) { + const aIndex = logLevels.indexOf(a); + if (aIndex < 0) throw new TypeError(`Invalid log level: ${JSON.stringify(a)}.`); + const bIndex = logLevels.indexOf(b); + if (bIndex < 0) throw new TypeError(`Invalid log level: ${JSON.stringify(b)}.`); + return aIndex - bIndex; +} + +//#endregion +//#region \0@oxc-project+runtime@0.95.0/helpers/typeof.js +function _typeof(o) { + "@babel/helpers - typeof"; + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(o$1) { + return typeof o$1; + } : function(o$1) { + return o$1 && "function" == typeof Symbol && o$1.constructor === Symbol && o$1 !== Symbol.prototype ? "symbol" : typeof o$1; + }, _typeof(o); +} + +//#endregion +//#region \0@oxc-project+runtime@0.95.0/helpers/toPrimitive.js +function toPrimitive(t, r) { + if ("object" != _typeof(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != _typeof(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + +//#endregion +//#region \0@oxc-project+runtime@0.95.0/helpers/toPropertyKey.js +function toPropertyKey(t) { + var i = toPrimitive(t, "string"); + return "symbol" == _typeof(i) ? i : i + ""; +} + +//#endregion +//#region \0@oxc-project+runtime@0.95.0/helpers/defineProperty.js +function _defineProperty(e, r, t) { + return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + +//#endregion +//#region node_modules/@logtape/logtape/dist/logger.js +/** +* Get a logger with the given category. +* +* ```typescript +* const logger = getLogger(["my-app"]); +* ``` +* +* @param category The category of the logger. It can be a string or an array +* of strings. If it is a string, it is equivalent to an array +* with a single element. +* @returns The logger. +*/ +function getLogger(category = []) { + return LoggerImpl.getLogger(category); +} +/** +* The symbol for the global root logger. +*/ +var globalRootLoggerSymbol = Symbol.for("logtape.rootLogger"); +/** +* A logger implementation. Do not use this directly; use {@link getLogger} +* instead. This class is exported for testing purposes. +*/ +var LoggerImpl = class LoggerImpl$1 { + static getLogger(category = []) { + let rootLogger = globalRootLoggerSymbol in globalThis ? globalThis[globalRootLoggerSymbol] ?? null : null; + if (rootLogger == null) { + rootLogger = new LoggerImpl$1(null, []); + globalThis[globalRootLoggerSymbol] = rootLogger; + } + if (typeof category === "string") return rootLogger.getChild(category); + if (category.length === 0) return rootLogger; + return rootLogger.getChild(category); + } + constructor(parent, category) { + _defineProperty(this, "parent", void 0); + _defineProperty(this, "children", void 0); + _defineProperty(this, "category", void 0); + _defineProperty(this, "sinks", void 0); + _defineProperty(this, "parentSinks", "inherit"); + _defineProperty(this, "filters", void 0); + _defineProperty(this, "lowestLevel", "trace"); + _defineProperty(this, "contextLocalStorage", void 0); + this.parent = parent; + this.children = {}; + this.category = category; + this.sinks = []; + this.filters = []; + } + getChild(subcategory) { + const name = typeof subcategory === "string" ? subcategory : subcategory[0]; + const childRef = this.children[name]; + let child = childRef instanceof LoggerImpl$1 ? childRef : childRef?.deref(); + if (child == null) { + child = new LoggerImpl$1(this, [...this.category, name]); + this.children[name] = "WeakRef" in globalThis ? new WeakRef(child) : child; + } + if (typeof subcategory === "string" || subcategory.length === 1) return child; + return child.getChild(subcategory.slice(1)); + } + /** + * Reset the logger. This removes all sinks and filters from the logger. + */ + reset() { + while (this.sinks.length > 0) this.sinks.shift(); + this.parentSinks = "inherit"; + while (this.filters.length > 0) this.filters.shift(); + this.lowestLevel = "trace"; + } + /** + * Reset the logger and all its descendants. This removes all sinks and + * filters from the logger and all its descendants. + */ + resetDescendants() { + for (const child of Object.values(this.children)) { + const logger$1 = child instanceof LoggerImpl$1 ? child : child.deref(); + if (logger$1 != null) logger$1.resetDescendants(); + } + this.reset(); + } + with(properties) { + return new LoggerCtx(this, { ...properties }); + } + filter(record) { + for (const filter of this.filters) if (!filter(record)) return false; + if (this.filters.length < 1) return this.parent?.filter(record) ?? true; + return true; + } + *getSinks(level$1) { + if (this.lowestLevel === null || compareLogLevel(level$1, this.lowestLevel) < 0) return; + if (this.parent != null && this.parentSinks === "inherit") for (const sink of this.parent.getSinks(level$1)) yield sink; + for (const sink of this.sinks) yield sink; + } + emit(record, bypassSinks) { + const fullRecord = "category" in record ? record : { + ...record, + category: this.category + }; + if (this.lowestLevel === null || compareLogLevel(fullRecord.level, this.lowestLevel) < 0 || !this.filter(fullRecord)) return; + for (const sink of this.getSinks(fullRecord.level)) { + if (bypassSinks?.has(sink)) continue; + try { + sink(fullRecord); + } catch (error) { + const bypassSinks2 = new Set(bypassSinks); + bypassSinks2.add(sink); + metaLogger.log("fatal", "Failed to emit a log record to sink {sink}: {error}", { + sink, + error, + record: fullRecord + }, bypassSinks2); + } + } + } + log(level$1, rawMessage, properties, bypassSinks) { + const implicitContext = LoggerImpl$1.getLogger().contextLocalStorage?.getStore() ?? {}; + let cachedProps = void 0; + const record = typeof properties === "function" ? { + category: this.category, + level: level$1, + timestamp: Date.now(), + get message() { + return parseMessageTemplate(rawMessage, this.properties); + }, + rawMessage, + get properties() { + if (cachedProps == null) cachedProps = { + ...implicitContext, + ...properties() + }; + return cachedProps; + } + } : { + category: this.category, + level: level$1, + timestamp: Date.now(), + message: parseMessageTemplate(rawMessage, { + ...implicitContext, + ...properties + }), + rawMessage, + properties: { + ...implicitContext, + ...properties + } + }; + this.emit(record, bypassSinks); + } + logLazily(level$1, callback, properties = {}) { + const implicitContext = LoggerImpl$1.getLogger().contextLocalStorage?.getStore() ?? {}; + let rawMessage = void 0; + let msg = void 0; + function realizeMessage() { + if (msg == null || rawMessage == null) { + msg = callback((tpl, ...values) => { + rawMessage = tpl; + return renderMessage(tpl, values); + }); + if (rawMessage == null) throw new TypeError("No log record was made."); + } + return [msg, rawMessage]; + } + this.emit({ + category: this.category, + level: level$1, + get message() { + return realizeMessage()[0]; + }, + get rawMessage() { + return realizeMessage()[1]; + }, + timestamp: Date.now(), + properties: { + ...implicitContext, + ...properties + } + }); + } + logTemplate(level$1, messageTemplate, values, properties = {}) { + const implicitContext = LoggerImpl$1.getLogger().contextLocalStorage?.getStore() ?? {}; + this.emit({ + category: this.category, + level: level$1, + message: renderMessage(messageTemplate, values), + rawMessage: messageTemplate, + timestamp: Date.now(), + properties: { + ...implicitContext, + ...properties + } + }); + } + trace(message, ...values) { + if (typeof message === "string") this.log("trace", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("trace", message); + else if (!Array.isArray(message)) this.log("trace", "{*}", message); + else this.logTemplate("trace", message, values); + } + debug(message, ...values) { + if (typeof message === "string") this.log("debug", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("debug", message); + else if (!Array.isArray(message)) this.log("debug", "{*}", message); + else this.logTemplate("debug", message, values); + } + info(message, ...values) { + if (typeof message === "string") this.log("info", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("info", message); + else if (!Array.isArray(message)) this.log("info", "{*}", message); + else this.logTemplate("info", message, values); + } + warn(message, ...values) { + if (typeof message === "string") this.log("warning", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("warning", message); + else if (!Array.isArray(message)) this.log("warning", "{*}", message); + else this.logTemplate("warning", message, values); + } + warning(message, ...values) { + this.warn(message, ...values); + } + error(message, ...values) { + if (typeof message === "string") this.log("error", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("error", message); + else if (!Array.isArray(message)) this.log("error", "{*}", message); + else this.logTemplate("error", message, values); + } + fatal(message, ...values) { + if (typeof message === "string") this.log("fatal", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("fatal", message); + else if (!Array.isArray(message)) this.log("fatal", "{*}", message); + else this.logTemplate("fatal", message, values); + } +}; +/** +* A logger implementation with contextual properties. Do not use this +* directly; use {@link Logger.with} instead. This class is exported +* for testing purposes. +*/ +var LoggerCtx = class LoggerCtx$1 { + constructor(logger$1, properties) { + _defineProperty(this, "logger", void 0); + _defineProperty(this, "properties", void 0); + this.logger = logger$1; + this.properties = properties; + } + get category() { + return this.logger.category; + } + get parent() { + return this.logger.parent; + } + getChild(subcategory) { + return this.logger.getChild(subcategory).with(this.properties); + } + with(properties) { + return new LoggerCtx$1(this.logger, { + ...this.properties, + ...properties + }); + } + log(level$1, message, properties, bypassSinks) { + this.logger.log(level$1, message, typeof properties === "function" ? () => ({ + ...this.properties, + ...properties() + }) : { + ...this.properties, + ...properties + }, bypassSinks); + } + logLazily(level$1, callback) { + this.logger.logLazily(level$1, callback, this.properties); + } + logTemplate(level$1, messageTemplate, values) { + this.logger.logTemplate(level$1, messageTemplate, values, this.properties); + } + emit(record) { + const recordWithContext = { + ...record, + properties: { + ...this.properties, + ...record.properties + } + }; + this.logger.emit(recordWithContext); + } + trace(message, ...values) { + if (typeof message === "string") this.log("trace", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("trace", message); + else if (!Array.isArray(message)) this.log("trace", "{*}", message); + else this.logTemplate("trace", message, values); + } + debug(message, ...values) { + if (typeof message === "string") this.log("debug", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("debug", message); + else if (!Array.isArray(message)) this.log("debug", "{*}", message); + else this.logTemplate("debug", message, values); + } + info(message, ...values) { + if (typeof message === "string") this.log("info", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("info", message); + else if (!Array.isArray(message)) this.log("info", "{*}", message); + else this.logTemplate("info", message, values); + } + warn(message, ...values) { + if (typeof message === "string") this.log("warning", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("warning", message); + else if (!Array.isArray(message)) this.log("warning", "{*}", message); + else this.logTemplate("warning", message, values); + } + warning(message, ...values) { + this.warn(message, ...values); + } + error(message, ...values) { + if (typeof message === "string") this.log("error", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("error", message); + else if (!Array.isArray(message)) this.log("error", "{*}", message); + else this.logTemplate("error", message, values); + } + fatal(message, ...values) { + if (typeof message === "string") this.log("fatal", message, values[0] ?? {}); + else if (typeof message === "function") this.logLazily("fatal", message); + else if (!Array.isArray(message)) this.log("fatal", "{*}", message); + else this.logTemplate("fatal", message, values); + } +}; +/** +* The meta logger. It is a logger with the category `["logtape", "meta"]`. +*/ +var metaLogger = LoggerImpl.getLogger(["logtape", "meta"]); +/** +* Parse a message template into a message template array and a values array. +* @param template The message template. +* @param properties The values to replace placeholders with. +* @returns The message template array and the values array. +*/ +function parseMessageTemplate(template, properties) { + const length = template.length; + if (length === 0) return [""]; + if (!template.includes("{")) return [template]; + const message = []; + let startIndex = 0; + for (let i = 0; i < length; i++) { + const char = template[i]; + if (char === "{") { + if ((i + 1 < length ? template[i + 1] : "") === "{") { + i++; + continue; + } + const closeIndex = template.indexOf("}", i + 1); + if (closeIndex === -1) continue; + const beforeText = template.slice(startIndex, i); + message.push(beforeText.replace(/{{/g, "{").replace(/}}/g, "}")); + const key = template.slice(i + 1, closeIndex); + let prop; + const trimmedKey = key.trim(); + if (trimmedKey === "*") prop = key in properties ? properties[key] : "*" in properties ? properties["*"] : properties; + else if (key !== trimmedKey) prop = key in properties ? properties[key] : properties[trimmedKey]; + else prop = properties[key]; + message.push(prop); + i = closeIndex; + startIndex = i + 1; + } else if (char === "}" && i + 1 < length && template[i + 1] === "}") i++; + } + const remainingText = template.slice(startIndex); + message.push(remainingText.replace(/{{/g, "{").replace(/}}/g, "}")); + return message; +} +/** +* Render a message template with values. +* @param template The message template. +* @param values The message template values. +* @returns The message template values interleaved between the substitution +* values. +*/ +function renderMessage(template, values) { + const args = []; + for (let i = 0; i < template.length; i++) { + args.push(template[i]); + if (i < values.length) args.push(values[i]); + } + return args; +} + +//#endregion +//#region node_modules/@logtape/logtape/dist/util.js +var util_exports = /* @__PURE__ */ __export({ inspect: () => inspect$1 }); +function inspect$1(obj, options) { + const indent = options?.compact === true ? void 0 : 2; + return JSON.stringify(obj, null, indent); +} + +//#endregion +//#region node_modules/@logtape/logtape/dist/formatter.js +/** +* The severity level abbreviations. +*/ +var levelAbbreviations = { + "trace": "TRC", + "debug": "DBG", + "info": "INF", + "warning": "WRN", + "error": "ERR", + "fatal": "FTL" +}; +/** +* A platform-specific inspect function. In Deno, this is {@link Deno.inspect}, +* and in Node.js/Bun it is `util.inspect()`. If neither is available, it +* falls back to {@link JSON.stringify}. +* +* @param value The value to inspect. +* @param options The options for inspecting the value. +* If `colors` is `true`, the output will be ANSI-colored. +* @returns The string representation of the value. +*/ +var inspect = typeof document !== "undefined" || typeof navigator !== "undefined" && navigator.product === "ReactNative" ? (v) => JSON.stringify(v) : "Deno" in globalThis && "inspect" in globalThis.Deno && typeof globalThis.Deno.inspect === "function" ? (v, opts) => globalThis.Deno.inspect(v, { + strAbbreviateSize: Infinity, + iterableLimit: Infinity, + ...opts +}) : util_exports != null && "inspect" in util_exports && typeof inspect$1 === "function" ? (v, opts) => inspect$1(v, { + maxArrayLength: Infinity, + maxStringLength: Infinity, + ...opts +}) : (v) => JSON.stringify(v); +function padZero(num) { + return num < 10 ? `0${num}` : `${num}`; +} +function padThree(num) { + return num < 10 ? `00${num}` : num < 100 ? `0${num}` : `${num}`; +} +var timestampFormatters = { + "date-time-timezone": (ts) => { + const d = new Date(ts); + return `${d.getUTCFullYear()}-${padZero(d.getUTCMonth() + 1)}-${padZero(d.getUTCDate())} ${padZero(d.getUTCHours())}:${padZero(d.getUTCMinutes())}:${padZero(d.getUTCSeconds())}.${padThree(d.getUTCMilliseconds())} +00:00`; + }, + "date-time-tz": (ts) => { + const d = new Date(ts); + return `${d.getUTCFullYear()}-${padZero(d.getUTCMonth() + 1)}-${padZero(d.getUTCDate())} ${padZero(d.getUTCHours())}:${padZero(d.getUTCMinutes())}:${padZero(d.getUTCSeconds())}.${padThree(d.getUTCMilliseconds())} +00`; + }, + "date-time": (ts) => { + const d = new Date(ts); + return `${d.getUTCFullYear()}-${padZero(d.getUTCMonth() + 1)}-${padZero(d.getUTCDate())} ${padZero(d.getUTCHours())}:${padZero(d.getUTCMinutes())}:${padZero(d.getUTCSeconds())}.${padThree(d.getUTCMilliseconds())}`; + }, + "time-timezone": (ts) => { + const d = new Date(ts); + return `${padZero(d.getUTCHours())}:${padZero(d.getUTCMinutes())}:${padZero(d.getUTCSeconds())}.${padThree(d.getUTCMilliseconds())} +00:00`; + }, + "time-tz": (ts) => { + const d = new Date(ts); + return `${padZero(d.getUTCHours())}:${padZero(d.getUTCMinutes())}:${padZero(d.getUTCSeconds())}.${padThree(d.getUTCMilliseconds())} +00`; + }, + "time": (ts) => { + const d = new Date(ts); + return `${padZero(d.getUTCHours())}:${padZero(d.getUTCMinutes())}:${padZero(d.getUTCSeconds())}.${padThree(d.getUTCMilliseconds())}`; + }, + "date": (ts) => { + const d = new Date(ts); + return `${d.getUTCFullYear()}-${padZero(d.getUTCMonth() + 1)}-${padZero(d.getUTCDate())}`; + }, + "rfc3339": (ts) => new Date(ts).toISOString(), + "none": () => null +}; +var levelRenderersCache = { + ABBR: levelAbbreviations, + abbr: { + trace: "trc", + debug: "dbg", + info: "inf", + warning: "wrn", + error: "err", + fatal: "ftl" + }, + FULL: { + trace: "TRACE", + debug: "DEBUG", + info: "INFO", + warning: "WARNING", + error: "ERROR", + fatal: "FATAL" + }, + full: { + trace: "trace", + debug: "debug", + info: "info", + warning: "warning", + error: "error", + fatal: "fatal" + }, + L: { + trace: "T", + debug: "D", + info: "I", + warning: "W", + error: "E", + fatal: "F" + }, + l: { + trace: "t", + debug: "d", + info: "i", + warning: "w", + error: "e", + fatal: "f" + } +}; +/** +* Get a text formatter with the specified options. Although it's flexible +* enough to create a custom formatter, if you want more control, you can +* create a custom formatter that satisfies the {@link TextFormatter} type +* instead. +* +* For more information on the options, see {@link TextFormatterOptions}. +* +* By default, the formatter formats log records as follows: +* +* ``` +* 2023-11-14 22:13:20.000 +00:00 [INF] category·subcategory: Hello, world! +* ``` +* @param options The options for the text formatter. +* @returns The text formatter. +* @since 0.6.0 +*/ +function getTextFormatter(options = {}) { + const timestampRenderer = (() => { + const tsOption = options.timestamp; + if (tsOption == null) return timestampFormatters["date-time-timezone"]; + else if (tsOption === "disabled") return timestampFormatters["none"]; + else if (typeof tsOption === "string" && tsOption in timestampFormatters) return timestampFormatters[tsOption]; + else return tsOption; + })(); + const categorySeparator = options.category ?? "·"; + const valueRenderer = options.value ?? inspect; + const levelRenderer = (() => { + const levelOption = options.level; + if (levelOption == null || levelOption === "ABBR") return (level$1) => levelRenderersCache.ABBR[level$1]; + else if (levelOption === "abbr") return (level$1) => levelRenderersCache.abbr[level$1]; + else if (levelOption === "FULL") return (level$1) => levelRenderersCache.FULL[level$1]; + else if (levelOption === "full") return (level$1) => levelRenderersCache.full[level$1]; + else if (levelOption === "L") return (level$1) => levelRenderersCache.L[level$1]; + else if (levelOption === "l") return (level$1) => levelRenderersCache.l[level$1]; + else return levelOption; + })(); + const formatter = options.format ?? (({ timestamp, level: level$1, category, message }) => `${timestamp ? `${timestamp} ` : ""}[${level$1}] ${category}: ${message}`); + return (record) => { + const msgParts = record.message; + const msgLen = msgParts.length; + let message; + if (msgLen === 1) message = msgParts[0]; + else if (msgLen <= 6) { + message = ""; + for (let i = 0; i < msgLen; i++) message += i % 2 === 0 ? msgParts[i] : valueRenderer(msgParts[i]); + } else { + const parts = new Array(msgLen); + for (let i = 0; i < msgLen; i++) parts[i] = i % 2 === 0 ? msgParts[i] : valueRenderer(msgParts[i]); + message = parts.join(""); + } + return `${formatter({ + timestamp: timestampRenderer(record.timestamp), + level: levelRenderer(record.level), + category: typeof categorySeparator === "function" ? categorySeparator(record.category) : record.category.join(categorySeparator), + message, + record + })}\n`; + }; +} +/** +* The default text formatter. This formatter formats log records as follows: +* +* ``` +* 2023-11-14 22:13:20.000 +00:00 [INF] category·subcategory: Hello, world! +* ``` +* +* @param record The log record to format. +* @returns The formatted log record. +*/ +var defaultTextFormatter = getTextFormatter(); +var RESET = "\x1B[0m"; +var ansiColors = { + black: "\x1B[30m", + red: "\x1B[31m", + green: "\x1B[32m", + yellow: "\x1B[33m", + blue: "\x1B[34m", + magenta: "\x1B[35m", + cyan: "\x1B[36m", + white: "\x1B[37m" +}; +var ansiStyles$1 = { + bold: "\x1B[1m", + dim: "\x1B[2m", + italic: "\x1B[3m", + underline: "\x1B[4m", + strikethrough: "\x1B[9m" +}; +var defaultLevelColors = { + trace: null, + debug: "blue", + info: "green", + warning: "yellow", + error: "red", + fatal: "magenta" +}; +/** +* Get an ANSI color formatter with the specified options. +* +* ![A preview of an ANSI color formatter.](https://i.imgur.com/I8LlBUf.png) +* @param option The options for the ANSI color formatter. +* @returns The ANSI color formatter. +* @since 0.6.0 +*/ +function getAnsiColorFormatter(options = {}) { + const format = options.format; + const timestampStyle = typeof options.timestampStyle === "undefined" ? "dim" : options.timestampStyle; + const timestampColor = options.timestampColor ?? null; + const timestampPrefix = `${timestampStyle == null ? "" : ansiStyles$1[timestampStyle]}${timestampColor == null ? "" : ansiColors[timestampColor]}`; + const timestampSuffix = timestampStyle == null && timestampColor == null ? "" : RESET; + const levelStyle = typeof options.levelStyle === "undefined" ? "bold" : options.levelStyle; + const levelColors = options.levelColors ?? defaultLevelColors; + const categoryStyle = typeof options.categoryStyle === "undefined" ? "dim" : options.categoryStyle; + const categoryColor = options.categoryColor ?? null; + const categoryPrefix = `${categoryStyle == null ? "" : ansiStyles$1[categoryStyle]}${categoryColor == null ? "" : ansiColors[categoryColor]}`; + const categorySuffix = categoryStyle == null && categoryColor == null ? "" : RESET; + return getTextFormatter({ + timestamp: "date-time-tz", + value(value) { + return inspect(value, { colors: true }); + }, + ...options, + format({ timestamp, level: level$1, category, message, record }) { + const levelColor = levelColors[record.level]; + timestamp = `${timestampPrefix}${timestamp}${timestampSuffix}`; + level$1 = `${levelStyle == null ? "" : ansiStyles$1[levelStyle]}${levelColor == null ? "" : ansiColors[levelColor]}${level$1}${levelStyle == null && levelColor == null ? "" : RESET}`; + return format == null ? `${timestamp} ${level$1} ${categoryPrefix}${category}:${categorySuffix} ${message}` : format({ + timestamp, + level: level$1, + category: `${categoryPrefix}${category}${categorySuffix}`, + message, + record + }); + } + }); +} +/** +* A text formatter that uses ANSI colors to format log records. +* +* ![A preview of ansiColorFormatter.](https://i.imgur.com/I8LlBUf.png) +* +* @param record The log record to format. +* @returns The formatted log record. +* @since 0.5.0 +*/ +var ansiColorFormatter = getAnsiColorFormatter(); +/** +* Get a [JSON Lines] formatter with the specified options. The log records +* will be rendered as JSON objects, one per line, which is a common format +* for log files. This format is also known as Newline-Delimited JSON (NDJSON). +* It looks like this: +* +* ```json +* {"@timestamp":"2023-11-14T22:13:20.000Z","level":"INFO","message":"Hello, world!","logger":"my.logger","properties":{"key":"value"}} +* ``` +* +* [JSON Lines]: https://jsonlines.org/ +* @param options The options for the JSON Lines formatter. +* @returns The JSON Lines formatter. +* @since 0.11.0 +*/ +function getJsonLinesFormatter(options = {}) { + if (!options.categorySeparator && !options.message && !options.properties) return (record) => { + if (record.message.length === 3) return JSON.stringify({ + "@timestamp": new Date(record.timestamp).toISOString(), + level: record.level === "warning" ? "WARN" : record.level.toUpperCase(), + message: record.message[0] + JSON.stringify(record.message[1]) + record.message[2], + logger: record.category.join("."), + properties: record.properties + }) + "\n"; + if (record.message.length === 1) return JSON.stringify({ + "@timestamp": new Date(record.timestamp).toISOString(), + level: record.level === "warning" ? "WARN" : record.level.toUpperCase(), + message: record.message[0], + logger: record.category.join("."), + properties: record.properties + }) + "\n"; + let msg = record.message[0]; + for (let i = 1; i < record.message.length; i++) msg += i & 1 ? JSON.stringify(record.message[i]) : record.message[i]; + return JSON.stringify({ + "@timestamp": new Date(record.timestamp).toISOString(), + level: record.level === "warning" ? "WARN" : record.level.toUpperCase(), + message: msg, + logger: record.category.join("."), + properties: record.properties + }) + "\n"; + }; + const isTemplateMessage = options.message === "template"; + const propertiesOption = options.properties ?? "nest:properties"; + let joinCategory; + if (typeof options.categorySeparator === "function") joinCategory = options.categorySeparator; + else { + const separator = options.categorySeparator ?? "."; + joinCategory = (category) => category.join(separator); + } + let getProperties; + if (propertiesOption === "flatten") getProperties = (properties) => properties; + else if (propertiesOption.startsWith("prepend:")) { + const prefix$1 = propertiesOption.substring(8); + if (prefix$1 === "") throw new TypeError(`Invalid properties option: ${JSON.stringify(propertiesOption)}. It must be of the form "prepend:" where is a non-empty string.`); + getProperties = (properties) => { + const result = {}; + for (const key in properties) result[`${prefix$1}${key}`] = properties[key]; + return result; + }; + } else if (propertiesOption.startsWith("nest:")) { + const key = propertiesOption.substring(5); + getProperties = (properties) => ({ [key]: properties }); + } else throw new TypeError(`Invalid properties option: ${JSON.stringify(propertiesOption)}. It must be "flatten", "prepend:", or "nest:".`); + let getMessage; + if (isTemplateMessage) getMessage = (record) => { + if (typeof record.rawMessage === "string") return record.rawMessage; + let msg = ""; + for (let i = 0; i < record.rawMessage.length; i++) msg += i % 2 < 1 ? record.rawMessage[i] : "{}"; + return msg; + }; + else getMessage = (record) => { + const msgLen = record.message.length; + if (msgLen === 1) return record.message[0]; + let msg = ""; + for (let i = 0; i < msgLen; i++) msg += i % 2 < 1 ? record.message[i] : JSON.stringify(record.message[i]); + return msg; + }; + return (record) => { + return JSON.stringify({ + "@timestamp": new Date(record.timestamp).toISOString(), + level: record.level === "warning" ? "WARN" : record.level.toUpperCase(), + message: getMessage(record), + logger: joinCategory(record.category), + ...getProperties(record.properties) + }) + "\n"; + }; +} +/** +* The default [JSON Lines] formatter. This formatter formats log records +* as JSON objects, one per line, which is a common format for log files. +* It looks like this: +* +* ```json +* {"@timestamp":"2023-11-14T22:13:20.000Z","level":"INFO","message":"Hello, world!","logger":"my.logger","properties":{"key":"value"}} +* ``` +* +* You can customize the output by passing options to +* {@link getJsonLinesFormatter}. For example, you can change the category +* separator, the message format, and how the properties are formatted. +* +* [JSON Lines]: https://jsonlines.org/ +* @since 0.11.0 +*/ +var jsonLinesFormatter = getJsonLinesFormatter(); +/** +* The styles for the log level in the console. +*/ +var logLevelStyles = { + "trace": "background-color: gray; color: white;", + "debug": "background-color: gray; color: white;", + "info": "background-color: white; color: black;", + "warning": "background-color: orange; color: black;", + "error": "background-color: red; color: white;", + "fatal": "background-color: maroon; color: white;" +}; +/** +* The default console formatter. +* +* @param record The log record to format. +* @returns The formatted log record, as an array of arguments for +* {@link console.log}. +*/ +function defaultConsoleFormatter(record) { + let msg = ""; + const values = []; + for (let i = 0; i < record.message.length; i++) if (i % 2 === 0) msg += record.message[i]; + else { + msg += "%o"; + values.push(record.message[i]); + } + const date = new Date(record.timestamp); + return [ + `%c${`${date.getUTCHours().toString().padStart(2, "0")}:${date.getUTCMinutes().toString().padStart(2, "0")}:${date.getUTCSeconds().toString().padStart(2, "0")}.${date.getUTCMilliseconds().toString().padStart(3, "0")}`} %c${levelAbbreviations[record.level]}%c %c${record.category.join("·")} %c${msg}`, + "color: gray;", + logLevelStyles[record.level], + "background-color: default;", + "color: gray;", + "color: default;", + ...values + ]; +} + +//#endregion +//#region node_modules/@logtape/logtape/dist/sink.js +/** +* A console sink factory that returns a sink that logs to the console. +* +* @param options The options for the sink. +* @returns A sink that logs to the console. If `nonBlocking` is enabled, +* returns a sink that also implements {@link Disposable}. +*/ +function getConsoleSink(options = {}) { + const formatter = options.formatter ?? defaultConsoleFormatter; + const levelMap = { + trace: "debug", + debug: "debug", + info: "info", + warning: "warn", + error: "error", + fatal: "error", + ...options.levelMap ?? {} + }; + const console$1 = options.console ?? globalThis.console; + const baseSink = (record) => { + const args = formatter(record); + const method = levelMap[record.level]; + if (method === void 0) throw new TypeError(`Invalid log level: ${record.level}.`); + if (typeof args === "string") { + const msg = args.replace(/\r?\n$/, ""); + console$1[method](msg); + } else console$1[method](...args); + }; + if (!options.nonBlocking) return baseSink; + const nonBlockingConfig = options.nonBlocking === true ? {} : options.nonBlocking; + const bufferSize = nonBlockingConfig.bufferSize ?? 100; + const flushInterval = nonBlockingConfig.flushInterval ?? 100; + const buffer = []; + let flushTimer = null; + let disposed = false; + let flushScheduled = false; + const maxBufferSize = bufferSize * 2; + function flush() { + if (buffer.length === 0) return; + const records = buffer.splice(0); + for (const record of records) try { + baseSink(record); + } catch {} + } + function scheduleFlush() { + if (flushScheduled) return; + flushScheduled = true; + setTimeout(() => { + flushScheduled = false; + flush(); + }, 0); + } + function startFlushTimer() { + if (flushTimer !== null || disposed) return; + flushTimer = setInterval(() => { + flush(); + }, flushInterval); + } + const nonBlockingSink = (record) => { + if (disposed) return; + if (buffer.length >= maxBufferSize) buffer.shift(); + buffer.push(record); + if (buffer.length >= bufferSize) scheduleFlush(); + else if (flushTimer === null) startFlushTimer(); + }; + nonBlockingSink[Symbol.dispose] = () => { + disposed = true; + if (flushTimer !== null) { + clearInterval(flushTimer); + flushTimer = null; + } + flush(); + }; + return nonBlockingSink; +} + +//#endregion +//#region node_modules/@logtape/logtape/dist/config.js +/** +* The current configuration, if any. Otherwise, `null`. +*/ +var currentConfig = null; +/** +* Strong references to the loggers. +* This is to prevent the loggers from being garbage collected so that their +* sinks and filters are not removed. +*/ +var strongRefs = /* @__PURE__ */ new Set(); +/** +* Disposables to dispose when resetting the configuration. +*/ +var disposables = /* @__PURE__ */ new Set(); +/** +* Async disposables to dispose when resetting the configuration. +*/ +var asyncDisposables = /* @__PURE__ */ new Set(); +/** +* Check if a config is for the meta logger. +*/ +function isLoggerConfigMeta(cfg) { + return cfg.category.length === 0 || cfg.category.length === 1 && cfg.category[0] === "logtape" || cfg.category.length === 2 && cfg.category[0] === "logtape" && cfg.category[1] === "meta"; +} +/** +* Configure sync loggers with the specified configuration. +* +* Note that if the given sinks or filters are disposable, they will be +* disposed when the configuration is reset, or when the process exits. +* +* Also note that passing async sinks or filters will throw. If +* necessary use {@link resetSync} or {@link disposeSync}. +* +* @example +* ```typescript +* configureSync({ +* sinks: { +* console: getConsoleSink(), +* }, +* loggers: [ +* { +* category: "my-app", +* sinks: ["console"], +* lowestLevel: "info", +* }, +* { +* category: "logtape", +* sinks: ["console"], +* lowestLevel: "error", +* }, +* ], +* }); +* ``` +* +* @param config The configuration. +* @since 0.9.0 +*/ +function configureSync(config) { + if (currentConfig != null && !config.reset) throw new ConfigError("Already configured; if you want to reset, turn on the reset flag."); + if (asyncDisposables.size > 0) throw new ConfigError("Previously configured async disposables are still active. Use configure() instead or explicitly dispose them using dispose()."); + resetSync(); + try { + configureInternal(config, false); + } catch (e) { + if (e instanceof ConfigError) resetSync(); + throw e; + } +} +function configureInternal(config, allowAsync) { + currentConfig = config; + let metaConfigured = false; + const configuredCategories = /* @__PURE__ */ new Set(); + for (const cfg of config.loggers) { + if (isLoggerConfigMeta(cfg)) metaConfigured = true; + const categoryKey = Array.isArray(cfg.category) ? JSON.stringify(cfg.category) : JSON.stringify([cfg.category]); + if (configuredCategories.has(categoryKey)) throw new ConfigError(`Duplicate logger configuration for category: ${categoryKey}. Each category can only be configured once.`); + configuredCategories.add(categoryKey); + const logger$1 = LoggerImpl.getLogger(cfg.category); + for (const sinkId of cfg.sinks ?? []) { + const sink = config.sinks[sinkId]; + if (!sink) throw new ConfigError(`Sink not found: ${sinkId}.`); + logger$1.sinks.push(sink); + } + logger$1.parentSinks = cfg.parentSinks ?? "inherit"; + if (cfg.lowestLevel !== void 0) logger$1.lowestLevel = cfg.lowestLevel; + for (const filterId of cfg.filters ?? []) { + const filter = config.filters?.[filterId]; + if (filter === void 0) throw new ConfigError(`Filter not found: ${filterId}.`); + logger$1.filters.push(toFilter(filter)); + } + strongRefs.add(logger$1); + } + LoggerImpl.getLogger().contextLocalStorage = config.contextLocalStorage; + for (const sink of Object.values(config.sinks)) { + if (Symbol.asyncDispose in sink) if (allowAsync) asyncDisposables.add(sink); + else throw new ConfigError("Async disposables cannot be used with configureSync()."); + if (Symbol.dispose in sink) disposables.add(sink); + } + for (const filter of Object.values(config.filters ?? {})) { + if (filter == null || typeof filter === "string") continue; + if (Symbol.asyncDispose in filter) if (allowAsync) asyncDisposables.add(filter); + else throw new ConfigError("Async disposables cannot be used with configureSync()."); + if (Symbol.dispose in filter) disposables.add(filter); + } + if (typeof globalThis.EdgeRuntime !== "string" && "process" in globalThis && !("Deno" in globalThis)) { + const proc = globalThis.process; + const onMethod = proc?.["on"]; + if (typeof onMethod === "function") onMethod.call(proc, "exit", allowAsync ? dispose : disposeSync); + } else addEventListener("unload", allowAsync ? dispose : disposeSync); + const meta = LoggerImpl.getLogger(["logtape", "meta"]); + if (!metaConfigured) meta.sinks.push(getConsoleSink()); + meta.info("LogTape loggers are configured. Note that LogTape itself uses the meta logger, which has category {metaLoggerCategory}. The meta logger purposes to log internal errors such as sink exceptions. If you are seeing this message, the meta logger is automatically configured. It's recommended to configure the meta logger with a separate sink so that you can easily notice if logging itself fails or is misconfigured. To turn off this message, configure the meta logger with higher log levels than {dismissLevel}. See also .", { + metaLoggerCategory: ["logtape", "meta"], + dismissLevel: "info" + }); +} +/** +* Reset the configuration. Mostly for testing purposes. Will not clear async +* sinks, only use with sync sinks. Use {@link reset} if you have async sinks. +* @since 0.9.0 +*/ +function resetSync() { + disposeSync(); + resetInternal(); +} +function resetInternal() { + const rootLogger = LoggerImpl.getLogger([]); + rootLogger.resetDescendants(); + delete rootLogger.contextLocalStorage; + strongRefs.clear(); + currentConfig = null; +} +/** +* Dispose of the disposables. +*/ +async function dispose() { + disposeSync(); + const promises = []; + for (const disposable of asyncDisposables) { + promises.push(disposable[Symbol.asyncDispose]()); + asyncDisposables.delete(disposable); + } + await Promise.all(promises); +} +/** +* Dispose of the sync disposables. Async disposables will be untouched, +* use {@link dispose} if you have async sinks. +* @since 0.9.0 +*/ +function disposeSync() { + for (const disposable of disposables) disposable[Symbol.dispose](); + disposables.clear(); +} +/** +* A configuration error. +*/ +var ConfigError = class extends Error { + /** + * Constructs a new configuration error. + * @param message The error message. + */ + constructor(message) { + super(message); + this.name = "ConfigureError"; + } +}; + +//#endregion +//#region node_modules/chalk/source/vendor/ansi-styles/index.js +var ANSI_BACKGROUND_OFFSET = 10; +var wrapAnsi16 = (offset = 0) => (code) => `\u001B[${code + offset}m`; +var wrapAnsi256 = (offset = 0) => (code) => `\u001B[${38 + offset};5;${code}m`; +var wrapAnsi16m = (offset = 0) => (red, green, blue) => `\u001B[${38 + offset};2;${red};${green};${blue}m`; +var styles$1 = { + modifier: { + reset: [0, 0], + bold: [1, 22], + dim: [2, 22], + italic: [3, 23], + underline: [4, 24], + overline: [53, 55], + inverse: [7, 27], + hidden: [8, 28], + strikethrough: [9, 29] + }, + color: { + black: [30, 39], + red: [31, 39], + green: [32, 39], + yellow: [33, 39], + blue: [34, 39], + magenta: [35, 39], + cyan: [36, 39], + white: [37, 39], + blackBright: [90, 39], + gray: [90, 39], + grey: [90, 39], + redBright: [91, 39], + greenBright: [92, 39], + yellowBright: [93, 39], + blueBright: [94, 39], + magentaBright: [95, 39], + cyanBright: [96, 39], + whiteBright: [97, 39] + }, + bgColor: { + bgBlack: [40, 49], + bgRed: [41, 49], + bgGreen: [42, 49], + bgYellow: [43, 49], + bgBlue: [44, 49], + bgMagenta: [45, 49], + bgCyan: [46, 49], + bgWhite: [47, 49], + bgBlackBright: [100, 49], + bgGray: [100, 49], + bgGrey: [100, 49], + bgRedBright: [101, 49], + bgGreenBright: [102, 49], + bgYellowBright: [103, 49], + bgBlueBright: [104, 49], + bgMagentaBright: [105, 49], + bgCyanBright: [106, 49], + bgWhiteBright: [107, 49] + } +}; +const modifierNames = Object.keys(styles$1.modifier); +const foregroundColorNames = Object.keys(styles$1.color); +const backgroundColorNames = Object.keys(styles$1.bgColor); +const colorNames = [...foregroundColorNames, ...backgroundColorNames]; +function assembleStyles() { + const codes = /* @__PURE__ */ new Map(); + for (const [groupName, group] of Object.entries(styles$1)) { + for (const [styleName, style] of Object.entries(group)) { + styles$1[styleName] = { + open: `\u001B[${style[0]}m`, + close: `\u001B[${style[1]}m` + }; + group[styleName] = styles$1[styleName]; + codes.set(style[0], style[1]); + } + Object.defineProperty(styles$1, groupName, { + value: group, + enumerable: false + }); + } + Object.defineProperty(styles$1, "codes", { + value: codes, + enumerable: false + }); + styles$1.color.close = "\x1B[39m"; + styles$1.bgColor.close = "\x1B[49m"; + styles$1.color.ansi = wrapAnsi16(); + styles$1.color.ansi256 = wrapAnsi256(); + styles$1.color.ansi16m = wrapAnsi16m(); + styles$1.bgColor.ansi = wrapAnsi16(ANSI_BACKGROUND_OFFSET); + styles$1.bgColor.ansi256 = wrapAnsi256(ANSI_BACKGROUND_OFFSET); + styles$1.bgColor.ansi16m = wrapAnsi16m(ANSI_BACKGROUND_OFFSET); + Object.defineProperties(styles$1, { + rgbToAnsi256: { + value(red, green, blue) { + if (red === green && green === blue) { + if (red < 8) return 16; + if (red > 248) return 231; + return Math.round((red - 8) / 247 * 24) + 232; + } + return 16 + 36 * Math.round(red / 255 * 5) + 6 * Math.round(green / 255 * 5) + Math.round(blue / 255 * 5); + }, + enumerable: false + }, + hexToRgb: { + value(hex) { + const matches = /[a-f\d]{6}|[a-f\d]{3}/i.exec(hex.toString(16)); + if (!matches) return [ + 0, + 0, + 0 + ]; + let [colorString] = matches; + if (colorString.length === 3) colorString = [...colorString].map((character) => character + character).join(""); + const integer = Number.parseInt(colorString, 16); + return [ + integer >> 16 & 255, + integer >> 8 & 255, + integer & 255 + ]; + }, + enumerable: false + }, + hexToAnsi256: { + value: (hex) => styles$1.rgbToAnsi256(...styles$1.hexToRgb(hex)), + enumerable: false + }, + ansi256ToAnsi: { + value(code) { + if (code < 8) return 30 + code; + if (code < 16) return 90 + (code - 8); + let red; + let green; + let blue; + if (code >= 232) { + red = ((code - 232) * 10 + 8) / 255; + green = red; + blue = red; + } else { + code -= 16; + const remainder = code % 36; + red = Math.floor(code / 36) / 5; + green = Math.floor(remainder / 6) / 5; + blue = remainder % 6 / 5; + } + const value = Math.max(red, green, blue) * 2; + if (value === 0) return 30; + let result = 30 + (Math.round(blue) << 2 | Math.round(green) << 1 | Math.round(red)); + if (value === 2) result += 60; + return result; + }, + enumerable: false + }, + rgbToAnsi: { + value: (red, green, blue) => styles$1.ansi256ToAnsi(styles$1.rgbToAnsi256(red, green, blue)), + enumerable: false + }, + hexToAnsi: { + value: (hex) => styles$1.ansi256ToAnsi(styles$1.hexToAnsi256(hex)), + enumerable: false + } + }); + return styles$1; +} +var ansiStyles = assembleStyles(); +var ansi_styles_default = ansiStyles; + +//#endregion +//#region node_modules/chalk/source/vendor/supports-color/browser.js +var level = (() => { + if (!("navigator" in globalThis)) return 0; + if (globalThis.navigator.userAgentData) { + const brand = navigator.userAgentData.brands.find(({ brand: brand$1 }) => brand$1 === "Chromium"); + if (brand && brand.version > 93) return 3; + } + if (/\b(Chrome|Chromium)\//.test(globalThis.navigator.userAgent)) return 1; + return 0; +})(); +var colorSupport = level !== 0 && { + level, + hasBasic: true, + has256: level >= 2, + has16m: level >= 3 +}; +var supportsColor = { + stdout: colorSupport, + stderr: colorSupport +}; +var browser_default = supportsColor; + +//#endregion +//#region node_modules/chalk/source/utilities.js +function stringReplaceAll(string, substring, replacer) { + let index = string.indexOf(substring); + if (index === -1) return string; + const substringLength = substring.length; + let endIndex = 0; + let returnValue = ""; + do { + returnValue += string.slice(endIndex, index) + substring + replacer; + endIndex = index + substringLength; + index = string.indexOf(substring, endIndex); + } while (index !== -1); + returnValue += string.slice(endIndex); + return returnValue; +} +function stringEncaseCRLFWithFirstIndex(string, prefix$1, postfix, index) { + let endIndex = 0; + let returnValue = ""; + do { + const gotCR = string[index - 1] === "\r"; + returnValue += string.slice(endIndex, gotCR ? index - 1 : index) + prefix$1 + (gotCR ? "\r\n" : "\n") + postfix; + endIndex = index + 1; + index = string.indexOf("\n", endIndex); + } while (index !== -1); + returnValue += string.slice(endIndex); + return returnValue; +} + +//#endregion +//#region node_modules/chalk/source/index.js +var { stdout: stdoutColor, stderr: stderrColor } = browser_default; +var GENERATOR = Symbol("GENERATOR"); +var STYLER = Symbol("STYLER"); +var IS_EMPTY = Symbol("IS_EMPTY"); +var levelMapping = [ + "ansi", + "ansi", + "ansi256", + "ansi16m" +]; +var styles = Object.create(null); +var applyOptions = (object, options = {}) => { + if (options.level && !(Number.isInteger(options.level) && options.level >= 0 && options.level <= 3)) throw new Error("The `level` option should be an integer from 0 to 3"); + const colorLevel = stdoutColor ? stdoutColor.level : 0; + object.level = options.level === void 0 ? colorLevel : options.level; +}; +var chalkFactory = (options) => { + const chalk$1 = (...strings) => strings.join(" "); + applyOptions(chalk$1, options); + Object.setPrototypeOf(chalk$1, createChalk.prototype); + return chalk$1; +}; +function createChalk(options) { + return chalkFactory(options); +} +Object.setPrototypeOf(createChalk.prototype, Function.prototype); +for (const [styleName, style] of Object.entries(ansi_styles_default)) styles[styleName] = { get() { + const builder = createBuilder(this, createStyler(style.open, style.close, this[STYLER]), this[IS_EMPTY]); + Object.defineProperty(this, styleName, { value: builder }); + return builder; +} }; +styles.visible = { get() { + const builder = createBuilder(this, this[STYLER], true); + Object.defineProperty(this, "visible", { value: builder }); + return builder; +} }; +var getModelAnsi = (model, level$1, type, ...arguments_) => { + if (model === "rgb") { + if (level$1 === "ansi16m") return ansi_styles_default[type].ansi16m(...arguments_); + if (level$1 === "ansi256") return ansi_styles_default[type].ansi256(ansi_styles_default.rgbToAnsi256(...arguments_)); + return ansi_styles_default[type].ansi(ansi_styles_default.rgbToAnsi(...arguments_)); + } + if (model === "hex") return getModelAnsi("rgb", level$1, type, ...ansi_styles_default.hexToRgb(...arguments_)); + return ansi_styles_default[type][model](...arguments_); +}; +for (const model of [ + "rgb", + "hex", + "ansi256" +]) { + styles[model] = { get() { + const { level: level$1 } = this; + return function(...arguments_) { + const styler = createStyler(getModelAnsi(model, levelMapping[level$1], "color", ...arguments_), ansi_styles_default.color.close, this[STYLER]); + return createBuilder(this, styler, this[IS_EMPTY]); + }; + } }; + const bgModel = "bg" + model[0].toUpperCase() + model.slice(1); + styles[bgModel] = { get() { + const { level: level$1 } = this; + return function(...arguments_) { + const styler = createStyler(getModelAnsi(model, levelMapping[level$1], "bgColor", ...arguments_), ansi_styles_default.bgColor.close, this[STYLER]); + return createBuilder(this, styler, this[IS_EMPTY]); + }; + } }; +} +var proto = Object.defineProperties(() => {}, { + ...styles, + level: { + enumerable: true, + get() { + return this[GENERATOR].level; + }, + set(level$1) { + this[GENERATOR].level = level$1; + } + } +}); +var createStyler = (open, close, parent) => { + let openAll; + let closeAll; + if (parent === void 0) { + openAll = open; + closeAll = close; + } else { + openAll = parent.openAll + open; + closeAll = close + parent.closeAll; + } + return { + open, + close, + openAll, + closeAll, + parent + }; +}; +var createBuilder = (self, _styler, _isEmpty) => { + const builder = (...arguments_) => applyStyle(builder, arguments_.length === 1 ? "" + arguments_[0] : arguments_.join(" ")); + Object.setPrototypeOf(builder, proto); + builder[GENERATOR] = self; + builder[STYLER] = _styler; + builder[IS_EMPTY] = _isEmpty; + return builder; +}; +var applyStyle = (self, string) => { + if (self.level <= 0 || !string) return self[IS_EMPTY] ? "" : string; + let styler = self[STYLER]; + if (styler === void 0) return string; + const { openAll, closeAll } = styler; + if (string.includes("\x1B")) while (styler !== void 0) { + string = stringReplaceAll(string, styler.close, styler.open); + styler = styler.parent; + } + const lfIndex = string.indexOf("\n"); + if (lfIndex !== -1) string = stringEncaseCRLFWithFirstIndex(string, closeAll, openAll, lfIndex); + return openAll + string + closeAll; +}; +Object.defineProperties(createChalk.prototype, styles); +var chalk = createChalk(); +const chalkStderr = createChalk({ level: stderrColor ? stderrColor.level : 0 }); +var source_default = chalk; + +//#endregion +//#region node_modules/loglevel/lib/loglevel.js +var require_loglevel = /* @__PURE__ */ __commonJS({ "node_modules/loglevel/lib/loglevel.js": ((exports, module) => { + (function(root, definition) { + if (typeof define === "function" && define.amd) define(definition); + else if (typeof module === "object" && module.exports) module.exports = definition(); + else root.log = definition(); + })(exports, function() { + var noop = function() {}; + var undefinedType = "undefined"; + var isIE = typeof window !== undefinedType && typeof window.navigator !== undefinedType && /Trident\/|MSIE /.test(window.navigator.userAgent); + var logMethods = [ + "trace", + "debug", + "info", + "warn", + "error" + ]; + var _loggersByName = {}; + var defaultLogger = null; + function bindMethod(obj, methodName) { + var method = obj[methodName]; + if (typeof method.bind === "function") return method.bind(obj); + else try { + return Function.prototype.bind.call(method, obj); + } catch (e) { + return function() { + return Function.prototype.apply.apply(method, [obj, arguments]); + }; + } + } + function traceForIE() { + if (console.log) if (console.log.apply) console.log.apply(console, arguments); + else Function.prototype.apply.apply(console.log, [console, arguments]); + if (console.trace) console.trace(); + } + function realMethod(methodName) { + if (methodName === "debug") methodName = "log"; + if (typeof console === undefinedType) return false; + else if (methodName === "trace" && isIE) return traceForIE; + else if (console[methodName] !== void 0) return bindMethod(console, methodName); + else if (console.log !== void 0) return bindMethod(console, "log"); + else return noop; + } + function replaceLoggingMethods() { + var level$1 = this.getLevel(); + for (var i = 0; i < logMethods.length; i++) { + var methodName = logMethods[i]; + this[methodName] = i < level$1 ? noop : this.methodFactory(methodName, level$1, this.name); + } + this.log = this.debug; + if (typeof console === undefinedType && level$1 < this.levels.SILENT) return "No console available for logging"; + } + function enableLoggingWhenConsoleArrives(methodName) { + return function() { + if (typeof console !== undefinedType) { + replaceLoggingMethods.call(this); + this[methodName].apply(this, arguments); + } + }; + } + function defaultMethodFactory(methodName, _level, _loggerName) { + return realMethod(methodName) || enableLoggingWhenConsoleArrives.apply(this, arguments); + } + function Logger(name, factory) { + var self = this; + /** + * The level inherited from a parent logger (or a global default). We + * cache this here rather than delegating to the parent so that it stays + * in sync with the actual logging methods that we have installed (the + * parent could change levels but we might not have rebuilt the loggers + * in this child yet). + * @type {number} + */ + var inheritedLevel; + /** + * The default level for this logger, if any. If set, this overrides + * `inheritedLevel`. + * @type {number|null} + */ + var defaultLevel; + /** + * A user-specific level for this logger. If set, this overrides + * `defaultLevel`. + * @type {number|null} + */ + var userLevel; + var storageKey = "loglevel"; + if (typeof name === "string") storageKey += ":" + name; + else if (typeof name === "symbol") storageKey = void 0; + function persistLevelIfPossible(levelNum) { + var levelName = (logMethods[levelNum] || "silent").toUpperCase(); + if (typeof window === undefinedType || !storageKey) return; + try { + window.localStorage[storageKey] = levelName; + return; + } catch (ignore) {} + try { + window.document.cookie = encodeURIComponent(storageKey) + "=" + levelName + ";"; + } catch (ignore) {} + } + function getPersistedLevel() { + var storedLevel; + if (typeof window === undefinedType || !storageKey) return; + try { + storedLevel = window.localStorage[storageKey]; + } catch (ignore) {} + if (typeof storedLevel === undefinedType) try { + var cookie = window.document.cookie; + var cookieName = encodeURIComponent(storageKey); + var location = cookie.indexOf(cookieName + "="); + if (location !== -1) storedLevel = /^([^;]+)/.exec(cookie.slice(location + cookieName.length + 1))[1]; + } catch (ignore) {} + if (self.levels[storedLevel] === void 0) storedLevel = void 0; + return storedLevel; + } + function clearPersistedLevel() { + if (typeof window === undefinedType || !storageKey) return; + try { + window.localStorage.removeItem(storageKey); + } catch (ignore) {} + try { + window.document.cookie = encodeURIComponent(storageKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 UTC"; + } catch (ignore) {} + } + function normalizeLevel(input) { + var level$1 = input; + if (typeof level$1 === "string" && self.levels[level$1.toUpperCase()] !== void 0) level$1 = self.levels[level$1.toUpperCase()]; + if (typeof level$1 === "number" && level$1 >= 0 && level$1 <= self.levels.SILENT) return level$1; + else throw new TypeError("log.setLevel() called with invalid level: " + input); + } + self.name = name; + self.levels = { + "TRACE": 0, + "DEBUG": 1, + "INFO": 2, + "WARN": 3, + "ERROR": 4, + "SILENT": 5 + }; + self.methodFactory = factory || defaultMethodFactory; + self.getLevel = function() { + if (userLevel != null) return userLevel; + else if (defaultLevel != null) return defaultLevel; + else return inheritedLevel; + }; + self.setLevel = function(level$1, persist) { + userLevel = normalizeLevel(level$1); + if (persist !== false) persistLevelIfPossible(userLevel); + return replaceLoggingMethods.call(self); + }; + self.setDefaultLevel = function(level$1) { + defaultLevel = normalizeLevel(level$1); + if (!getPersistedLevel()) self.setLevel(level$1, false); + }; + self.resetLevel = function() { + userLevel = null; + clearPersistedLevel(); + replaceLoggingMethods.call(self); + }; + self.enableAll = function(persist) { + self.setLevel(self.levels.TRACE, persist); + }; + self.disableAll = function(persist) { + self.setLevel(self.levels.SILENT, persist); + }; + self.rebuild = function() { + if (defaultLogger !== self) inheritedLevel = normalizeLevel(defaultLogger.getLevel()); + replaceLoggingMethods.call(self); + if (defaultLogger === self) for (var childName in _loggersByName) _loggersByName[childName].rebuild(); + }; + inheritedLevel = normalizeLevel(defaultLogger ? defaultLogger.getLevel() : "WARN"); + var initialLevel = getPersistedLevel(); + if (initialLevel != null) userLevel = normalizeLevel(initialLevel); + replaceLoggingMethods.call(self); + } + defaultLogger = new Logger(); + defaultLogger.getLogger = function getLogger$1(name) { + if (typeof name !== "symbol" && typeof name !== "string" || name === "") throw new TypeError("You must supply a name when creating a logger."); + var logger$1 = _loggersByName[name]; + if (!logger$1) logger$1 = _loggersByName[name] = new Logger(name, defaultLogger.methodFactory); + return logger$1; + }; + var _log = typeof window !== undefinedType ? window.log : void 0; + defaultLogger.noConflict = function() { + if (typeof window !== undefinedType && window.log === defaultLogger) window.log = _log; + return defaultLogger; + }; + defaultLogger.getLoggers = function getLoggers() { + return _loggersByName; + }; + defaultLogger["default"] = defaultLogger; + return defaultLogger; + }); +}) }); + +//#endregion +//#region node_modules/loglevel-plugin-prefix/lib/loglevel-plugin-prefix.js +var require_loglevel_plugin_prefix = /* @__PURE__ */ __commonJS({ "node_modules/loglevel-plugin-prefix/lib/loglevel-plugin-prefix.js": ((exports, module) => { + (function(root, factory) { + if (typeof define === "function" && define.amd) define(factory); + else if (typeof module === "object" && module.exports) module.exports = factory(); + else root.prefix = factory(root); + })(exports, function(root) { + var merge = function(target) { + var i = 1; + var length = arguments.length; + var key; + for (; i < length; i++) for (key in arguments[i]) if (Object.prototype.hasOwnProperty.call(arguments[i], key)) target[key] = arguments[i][key]; + return target; + }; + var defaults = { + template: "[%t] %l:", + levelFormatter: function(level$1) { + return level$1.toUpperCase(); + }, + nameFormatter: function(name) { + return name || "root"; + }, + timestampFormatter: function(date) { + return date.toTimeString().replace(/.*(\d{2}:\d{2}:\d{2}).*/, "$1"); + }, + format: void 0 + }; + var loglevel; + var configs = {}; + var reg = function(rootLogger) { + if (!rootLogger || !rootLogger.getLogger) throw new TypeError("Argument is not a root logger"); + loglevel = rootLogger; + }; + var apply = function(logger$1, config) { + if (!logger$1 || !logger$1.setLevel) throw new TypeError("Argument is not a logger"); + var originalFactory = logger$1.methodFactory; + var name = logger$1.name || ""; + var parent = configs[name] || configs[""] || defaults; + function methodFactory(methodName, logLevel, loggerName) { + var originalMethod = originalFactory(methodName, logLevel, loggerName); + var options = configs[loggerName] || configs[""]; + var hasTimestamp = options.template.indexOf("%t") !== -1; + var hasLevel = options.template.indexOf("%l") !== -1; + var hasName = options.template.indexOf("%n") !== -1; + return function() { + var content = ""; + var length = arguments.length; + var args = Array(length); + var key = 0; + for (; key < length; key++) args[key] = arguments[key]; + if (name || !configs[loggerName]) { + var timestamp = options.timestampFormatter(/* @__PURE__ */ new Date()); + var level$1 = options.levelFormatter(methodName); + var lname = options.nameFormatter(loggerName); + if (options.format) content += options.format(level$1, lname, timestamp); + else { + content += options.template; + if (hasTimestamp) content = content.replace(/%t/, timestamp); + if (hasLevel) content = content.replace(/%l/, level$1); + if (hasName) content = content.replace(/%n/, lname); + } + if (args.length && typeof args[0] === "string") args[0] = content + " " + args[0]; + else args.unshift(content); + } + originalMethod.apply(void 0, args); + }; + } + if (!configs[name]) logger$1.methodFactory = methodFactory; + config = config || {}; + if (config.template) config.format = void 0; + configs[name] = merge({}, parent, config); + logger$1.setLevel(logger$1.getLevel()); + if (!loglevel) logger$1.warn("It is necessary to call the function reg() of loglevel-plugin-prefix before calling apply. From the next release, it will throw an error. See more: https://github.com/kutuluk/loglevel-plugin-prefix/blob/master/README.md"); + return logger$1; + }; + var api = { + reg, + apply + }; + var save; + if (root) { + save = root.prefix; + api.noConflict = function() { + if (root.prefix === api) root.prefix = save; + return api; + }; + } + return api; + }); +}) }); + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/journalisation.ts +var import_loglevel = /* @__PURE__ */ __toESM(require_loglevel(), 1); +var import_loglevel_plugin_prefix = /* @__PURE__ */ __toESM(require_loglevel_plugin_prefix(), 1); +var environment = { + "BASE_URL": "/", + "DEV": false, + "MODE": "development", + "PROD": true, + "SSR": false, + "VITE_GLITCHTIP_NSD": "https://14362801769747a4b7c1e04eb0c7a3cc@collie.haikuatelier.com/1", + "VITE_MODE": "development", + "VITE_PAYPAL_CLIENT_ID": "AbZ2PWvIqEFxD8-Gw1qhuyAcZZpyzlFZKz0ZIRlZxlLAQqQTYWUJo-OvyzxHs65s0eArdDtMSdNoDBzB", + "VITE_URL": "https://haikuatelier.fr.ddev.site" +}; +var colors = { + DEBUG: source_default.cyan, + ERROR: source_default.red, + INFO: source_default.blue, + TRACE: source_default.magenta, + WARN: source_default.yellow +}; +const logger = import_loglevel.default.noConflict(); +logger.enableAll(true); +logger.setDefaultLevel("DEBUG"); +import_loglevel_plugin_prefix.default.reg(logger); +import_loglevel_plugin_prefix.default.apply(logger, { format(level$1, _, timestamp) { + return `${source_default.gray(`[${timestamp}]`)} ${colors[level$1.toUpperCase()](level$1)}`; +} }); +var HAIKU_ATELIER_LOGGER = "haiku-atelier"; +configureSync({ + loggers: [{ + category: HAIKU_ATELIER_LOGGER, + lowestLevel: environment.VITE_MODE === "production" ? "warning" : "debug", + sinks: ["console"] + }], + sinks: { console: getConsoleSink() } +}); +const nuLogger = getLogger(HAIKU_ATELIER_LOGGER); + +//#endregion +export { nuLogger as n, _defineProperty as r, logger as t }; +//# sourceMappingURL=journalisation.CEgm28xa.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js.map b/web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js.map new file mode 100644 index 00000000..33536397 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/journalisation.CEgm28xa.js.map @@ -0,0 +1 @@ +{"version":3,"file":"journalisation.CEgm28xa.js","names":["level","LoggerImpl","logger","level","LoggerCtx","inspect","util","util.inspect","level","ansiStyles","prefix","console","logger","styles","brand","prefix","supportsColor","chalk","ansiStyles","level","level","getLogger","logger","level","logger","logger: Logger"],"sources":["../../../../../../node_modules/@logtape/logtape/dist/filter.js","../../../../../../node_modules/@logtape/logtape/dist/level.js","../../../../../../node_modules/@logtape/logtape/dist/logger.js","../../../../../../node_modules/@logtape/logtape/dist/util.js","../../../../../../node_modules/@logtape/logtape/dist/formatter.js","../../../../../../node_modules/@logtape/logtape/dist/sink.js","../../../../../../node_modules/@logtape/logtape/dist/config.js","../../../../../../node_modules/chalk/source/vendor/ansi-styles/index.js","../../../../../../node_modules/chalk/source/vendor/supports-color/browser.js","../../../../../../node_modules/chalk/source/utilities.js","../../../../../../node_modules/chalk/source/index.js","../../../../../../node_modules/loglevel/lib/loglevel.js","../../../../../../node_modules/loglevel-plugin-prefix/lib/loglevel-plugin-prefix.js","../../src/scripts/journalisation.ts"],"sourcesContent":["//#region src/filter.ts\n/**\n* Converts a {@link FilterLike} value to an actual {@link Filter}.\n*\n* @param filter The filter-like value to convert.\n* @returns The actual filter.\n*/\nfunction toFilter(filter) {\n\tif (typeof filter === \"function\") return filter;\n\treturn getLevelFilter(filter);\n}\n/**\n* Returns a filter that accepts log records with the specified level.\n*\n* @param level The level to filter by. If `null`, the filter will reject all\n* records.\n* @returns The filter.\n*/\nfunction getLevelFilter(level) {\n\tif (level == null) return () => false;\n\tif (level === \"fatal\") return (record) => record.level === \"fatal\";\n\telse if (level === \"error\") return (record) => record.level === \"fatal\" || record.level === \"error\";\n\telse if (level === \"warning\") return (record) => record.level === \"fatal\" || record.level === \"error\" || record.level === \"warning\";\n\telse if (level === \"info\") return (record) => record.level === \"fatal\" || record.level === \"error\" || record.level === \"warning\" || record.level === \"info\";\n\telse if (level === \"debug\") return (record) => record.level === \"fatal\" || record.level === \"error\" || record.level === \"warning\" || record.level === \"info\" || record.level === \"debug\";\n\telse if (level === \"trace\") return () => true;\n\tthrow new TypeError(`Invalid log level: ${level}.`);\n}\n\n//#endregion\nexport { getLevelFilter, toFilter };\n//# sourceMappingURL=filter.js.map","//#region src/level.ts\nconst logLevels = [\n\t\"trace\",\n\t\"debug\",\n\t\"info\",\n\t\"warning\",\n\t\"error\",\n\t\"fatal\"\n];\n/**\n* Lists all available log levels with the order of their severity.\n* The `\"trace\"` level goes first, and the `\"fatal\"` level goes last.\n* @returns A new copy of the array of log levels.\n* @since 1.0.0\n*/\nfunction getLogLevels() {\n\treturn [...logLevels];\n}\n/**\n* Parses a log level from a string.\n*\n* @param level The log level as a string. This is case-insensitive.\n* @returns The log level.\n* @throws {TypeError} If the log level is invalid.\n*/\nfunction parseLogLevel(level) {\n\tlevel = level.toLowerCase();\n\tswitch (level) {\n\t\tcase \"trace\":\n\t\tcase \"debug\":\n\t\tcase \"info\":\n\t\tcase \"warning\":\n\t\tcase \"error\":\n\t\tcase \"fatal\": return level;\n\t\tdefault: throw new TypeError(`Invalid log level: ${level}.`);\n\t}\n}\n/**\n* Checks if a string is a valid log level. This function can be used as\n* as a type guard to narrow the type of a string to a {@link LogLevel}.\n*\n* @param level The log level as a string. This is case-sensitive.\n* @returns `true` if the string is a valid log level.\n*/\nfunction isLogLevel(level) {\n\tswitch (level) {\n\t\tcase \"trace\":\n\t\tcase \"debug\":\n\t\tcase \"info\":\n\t\tcase \"warning\":\n\t\tcase \"error\":\n\t\tcase \"fatal\": return true;\n\t\tdefault: return false;\n\t}\n}\n/**\n* Compares two log levels.\n* @param a The first log level.\n* @param b The second log level.\n* @returns A negative number if `a` is less than `b`, a positive number if `a`\n* is greater than `b`, or zero if they are equal.\n* @since 0.8.0\n*/\nfunction compareLogLevel(a, b) {\n\tconst aIndex = logLevels.indexOf(a);\n\tif (aIndex < 0) throw new TypeError(`Invalid log level: ${JSON.stringify(a)}.`);\n\tconst bIndex = logLevels.indexOf(b);\n\tif (bIndex < 0) throw new TypeError(`Invalid log level: ${JSON.stringify(b)}.`);\n\treturn aIndex - bIndex;\n}\n\n//#endregion\nexport { compareLogLevel, getLogLevels, isLogLevel, parseLogLevel };\n//# sourceMappingURL=level.js.map","import { compareLogLevel } from \"./level.js\";\n\n//#region src/logger.ts\n/**\n* Get a logger with the given category.\n*\n* ```typescript\n* const logger = getLogger([\"my-app\"]);\n* ```\n*\n* @param category The category of the logger. It can be a string or an array\n* of strings. If it is a string, it is equivalent to an array\n* with a single element.\n* @returns The logger.\n*/\nfunction getLogger(category = []) {\n\treturn LoggerImpl.getLogger(category);\n}\n/**\n* The symbol for the global root logger.\n*/\nconst globalRootLoggerSymbol = Symbol.for(\"logtape.rootLogger\");\n/**\n* A logger implementation. Do not use this directly; use {@link getLogger}\n* instead. This class is exported for testing purposes.\n*/\nvar LoggerImpl = class LoggerImpl {\n\tparent;\n\tchildren;\n\tcategory;\n\tsinks;\n\tparentSinks = \"inherit\";\n\tfilters;\n\tlowestLevel = \"trace\";\n\tcontextLocalStorage;\n\tstatic getLogger(category = []) {\n\t\tlet rootLogger = globalRootLoggerSymbol in globalThis ? globalThis[globalRootLoggerSymbol] ?? null : null;\n\t\tif (rootLogger == null) {\n\t\t\trootLogger = new LoggerImpl(null, []);\n\t\t\tglobalThis[globalRootLoggerSymbol] = rootLogger;\n\t\t}\n\t\tif (typeof category === \"string\") return rootLogger.getChild(category);\n\t\tif (category.length === 0) return rootLogger;\n\t\treturn rootLogger.getChild(category);\n\t}\n\tconstructor(parent, category) {\n\t\tthis.parent = parent;\n\t\tthis.children = {};\n\t\tthis.category = category;\n\t\tthis.sinks = [];\n\t\tthis.filters = [];\n\t}\n\tgetChild(subcategory) {\n\t\tconst name = typeof subcategory === \"string\" ? subcategory : subcategory[0];\n\t\tconst childRef = this.children[name];\n\t\tlet child = childRef instanceof LoggerImpl ? childRef : childRef?.deref();\n\t\tif (child == null) {\n\t\t\tchild = new LoggerImpl(this, [...this.category, name]);\n\t\t\tthis.children[name] = \"WeakRef\" in globalThis ? new WeakRef(child) : child;\n\t\t}\n\t\tif (typeof subcategory === \"string\" || subcategory.length === 1) return child;\n\t\treturn child.getChild(subcategory.slice(1));\n\t}\n\t/**\n\t* Reset the logger. This removes all sinks and filters from the logger.\n\t*/\n\treset() {\n\t\twhile (this.sinks.length > 0) this.sinks.shift();\n\t\tthis.parentSinks = \"inherit\";\n\t\twhile (this.filters.length > 0) this.filters.shift();\n\t\tthis.lowestLevel = \"trace\";\n\t}\n\t/**\n\t* Reset the logger and all its descendants. This removes all sinks and\n\t* filters from the logger and all its descendants.\n\t*/\n\tresetDescendants() {\n\t\tfor (const child of Object.values(this.children)) {\n\t\t\tconst logger = child instanceof LoggerImpl ? child : child.deref();\n\t\t\tif (logger != null) logger.resetDescendants();\n\t\t}\n\t\tthis.reset();\n\t}\n\twith(properties) {\n\t\treturn new LoggerCtx(this, { ...properties });\n\t}\n\tfilter(record) {\n\t\tfor (const filter of this.filters) if (!filter(record)) return false;\n\t\tif (this.filters.length < 1) return this.parent?.filter(record) ?? true;\n\t\treturn true;\n\t}\n\t*getSinks(level) {\n\t\tif (this.lowestLevel === null || compareLogLevel(level, this.lowestLevel) < 0) return;\n\t\tif (this.parent != null && this.parentSinks === \"inherit\") for (const sink of this.parent.getSinks(level)) yield sink;\n\t\tfor (const sink of this.sinks) yield sink;\n\t}\n\temit(record, bypassSinks) {\n\t\tconst fullRecord = \"category\" in record ? record : {\n\t\t\t...record,\n\t\t\tcategory: this.category\n\t\t};\n\t\tif (this.lowestLevel === null || compareLogLevel(fullRecord.level, this.lowestLevel) < 0 || !this.filter(fullRecord)) return;\n\t\tfor (const sink of this.getSinks(fullRecord.level)) {\n\t\t\tif (bypassSinks?.has(sink)) continue;\n\t\t\ttry {\n\t\t\t\tsink(fullRecord);\n\t\t\t} catch (error) {\n\t\t\t\tconst bypassSinks2 = new Set(bypassSinks);\n\t\t\t\tbypassSinks2.add(sink);\n\t\t\t\tmetaLogger.log(\"fatal\", \"Failed to emit a log record to sink {sink}: {error}\", {\n\t\t\t\t\tsink,\n\t\t\t\t\terror,\n\t\t\t\t\trecord: fullRecord\n\t\t\t\t}, bypassSinks2);\n\t\t\t}\n\t\t}\n\t}\n\tlog(level, rawMessage, properties, bypassSinks) {\n\t\tconst implicitContext = LoggerImpl.getLogger().contextLocalStorage?.getStore() ?? {};\n\t\tlet cachedProps = void 0;\n\t\tconst record = typeof properties === \"function\" ? {\n\t\t\tcategory: this.category,\n\t\t\tlevel,\n\t\t\ttimestamp: Date.now(),\n\t\t\tget message() {\n\t\t\t\treturn parseMessageTemplate(rawMessage, this.properties);\n\t\t\t},\n\t\t\trawMessage,\n\t\t\tget properties() {\n\t\t\t\tif (cachedProps == null) cachedProps = {\n\t\t\t\t\t...implicitContext,\n\t\t\t\t\t...properties()\n\t\t\t\t};\n\t\t\t\treturn cachedProps;\n\t\t\t}\n\t\t} : {\n\t\t\tcategory: this.category,\n\t\t\tlevel,\n\t\t\ttimestamp: Date.now(),\n\t\t\tmessage: parseMessageTemplate(rawMessage, {\n\t\t\t\t...implicitContext,\n\t\t\t\t...properties\n\t\t\t}),\n\t\t\trawMessage,\n\t\t\tproperties: {\n\t\t\t\t...implicitContext,\n\t\t\t\t...properties\n\t\t\t}\n\t\t};\n\t\tthis.emit(record, bypassSinks);\n\t}\n\tlogLazily(level, callback, properties = {}) {\n\t\tconst implicitContext = LoggerImpl.getLogger().contextLocalStorage?.getStore() ?? {};\n\t\tlet rawMessage = void 0;\n\t\tlet msg = void 0;\n\t\tfunction realizeMessage() {\n\t\t\tif (msg == null || rawMessage == null) {\n\t\t\t\tmsg = callback((tpl, ...values) => {\n\t\t\t\t\trawMessage = tpl;\n\t\t\t\t\treturn renderMessage(tpl, values);\n\t\t\t\t});\n\t\t\t\tif (rawMessage == null) throw new TypeError(\"No log record was made.\");\n\t\t\t}\n\t\t\treturn [msg, rawMessage];\n\t\t}\n\t\tthis.emit({\n\t\t\tcategory: this.category,\n\t\t\tlevel,\n\t\t\tget message() {\n\t\t\t\treturn realizeMessage()[0];\n\t\t\t},\n\t\t\tget rawMessage() {\n\t\t\t\treturn realizeMessage()[1];\n\t\t\t},\n\t\t\ttimestamp: Date.now(),\n\t\t\tproperties: {\n\t\t\t\t...implicitContext,\n\t\t\t\t...properties\n\t\t\t}\n\t\t});\n\t}\n\tlogTemplate(level, messageTemplate, values, properties = {}) {\n\t\tconst implicitContext = LoggerImpl.getLogger().contextLocalStorage?.getStore() ?? {};\n\t\tthis.emit({\n\t\t\tcategory: this.category,\n\t\t\tlevel,\n\t\t\tmessage: renderMessage(messageTemplate, values),\n\t\t\trawMessage: messageTemplate,\n\t\t\ttimestamp: Date.now(),\n\t\t\tproperties: {\n\t\t\t\t...implicitContext,\n\t\t\t\t...properties\n\t\t\t}\n\t\t});\n\t}\n\ttrace(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"trace\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"trace\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"trace\", \"{*}\", message);\n\t\telse this.logTemplate(\"trace\", message, values);\n\t}\n\tdebug(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"debug\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"debug\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"debug\", \"{*}\", message);\n\t\telse this.logTemplate(\"debug\", message, values);\n\t}\n\tinfo(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"info\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"info\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"info\", \"{*}\", message);\n\t\telse this.logTemplate(\"info\", message, values);\n\t}\n\twarn(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"warning\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"warning\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"warning\", \"{*}\", message);\n\t\telse this.logTemplate(\"warning\", message, values);\n\t}\n\twarning(message, ...values) {\n\t\tthis.warn(message, ...values);\n\t}\n\terror(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"error\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"error\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"error\", \"{*}\", message);\n\t\telse this.logTemplate(\"error\", message, values);\n\t}\n\tfatal(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"fatal\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"fatal\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"fatal\", \"{*}\", message);\n\t\telse this.logTemplate(\"fatal\", message, values);\n\t}\n};\n/**\n* A logger implementation with contextual properties. Do not use this\n* directly; use {@link Logger.with} instead. This class is exported\n* for testing purposes.\n*/\nvar LoggerCtx = class LoggerCtx {\n\tlogger;\n\tproperties;\n\tconstructor(logger, properties) {\n\t\tthis.logger = logger;\n\t\tthis.properties = properties;\n\t}\n\tget category() {\n\t\treturn this.logger.category;\n\t}\n\tget parent() {\n\t\treturn this.logger.parent;\n\t}\n\tgetChild(subcategory) {\n\t\treturn this.logger.getChild(subcategory).with(this.properties);\n\t}\n\twith(properties) {\n\t\treturn new LoggerCtx(this.logger, {\n\t\t\t...this.properties,\n\t\t\t...properties\n\t\t});\n\t}\n\tlog(level, message, properties, bypassSinks) {\n\t\tthis.logger.log(level, message, typeof properties === \"function\" ? () => ({\n\t\t\t...this.properties,\n\t\t\t...properties()\n\t\t}) : {\n\t\t\t...this.properties,\n\t\t\t...properties\n\t\t}, bypassSinks);\n\t}\n\tlogLazily(level, callback) {\n\t\tthis.logger.logLazily(level, callback, this.properties);\n\t}\n\tlogTemplate(level, messageTemplate, values) {\n\t\tthis.logger.logTemplate(level, messageTemplate, values, this.properties);\n\t}\n\temit(record) {\n\t\tconst recordWithContext = {\n\t\t\t...record,\n\t\t\tproperties: {\n\t\t\t\t...this.properties,\n\t\t\t\t...record.properties\n\t\t\t}\n\t\t};\n\t\tthis.logger.emit(recordWithContext);\n\t}\n\ttrace(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"trace\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"trace\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"trace\", \"{*}\", message);\n\t\telse this.logTemplate(\"trace\", message, values);\n\t}\n\tdebug(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"debug\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"debug\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"debug\", \"{*}\", message);\n\t\telse this.logTemplate(\"debug\", message, values);\n\t}\n\tinfo(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"info\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"info\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"info\", \"{*}\", message);\n\t\telse this.logTemplate(\"info\", message, values);\n\t}\n\twarn(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"warning\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"warning\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"warning\", \"{*}\", message);\n\t\telse this.logTemplate(\"warning\", message, values);\n\t}\n\twarning(message, ...values) {\n\t\tthis.warn(message, ...values);\n\t}\n\terror(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"error\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"error\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"error\", \"{*}\", message);\n\t\telse this.logTemplate(\"error\", message, values);\n\t}\n\tfatal(message, ...values) {\n\t\tif (typeof message === \"string\") this.log(\"fatal\", message, values[0] ?? {});\n\t\telse if (typeof message === \"function\") this.logLazily(\"fatal\", message);\n\t\telse if (!Array.isArray(message)) this.log(\"fatal\", \"{*}\", message);\n\t\telse this.logTemplate(\"fatal\", message, values);\n\t}\n};\n/**\n* The meta logger. It is a logger with the category `[\"logtape\", \"meta\"]`.\n*/\nconst metaLogger = LoggerImpl.getLogger([\"logtape\", \"meta\"]);\n/**\n* Parse a message template into a message template array and a values array.\n* @param template The message template.\n* @param properties The values to replace placeholders with.\n* @returns The message template array and the values array.\n*/\nfunction parseMessageTemplate(template, properties) {\n\tconst length = template.length;\n\tif (length === 0) return [\"\"];\n\tif (!template.includes(\"{\")) return [template];\n\tconst message = [];\n\tlet startIndex = 0;\n\tfor (let i = 0; i < length; i++) {\n\t\tconst char = template[i];\n\t\tif (char === \"{\") {\n\t\t\tconst nextChar = i + 1 < length ? template[i + 1] : \"\";\n\t\t\tif (nextChar === \"{\") {\n\t\t\t\ti++;\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tconst closeIndex = template.indexOf(\"}\", i + 1);\n\t\t\tif (closeIndex === -1) continue;\n\t\t\tconst beforeText = template.slice(startIndex, i);\n\t\t\tmessage.push(beforeText.replace(/{{/g, \"{\").replace(/}}/g, \"}\"));\n\t\t\tconst key = template.slice(i + 1, closeIndex);\n\t\t\tlet prop;\n\t\t\tconst trimmedKey = key.trim();\n\t\t\tif (trimmedKey === \"*\") prop = key in properties ? properties[key] : \"*\" in properties ? properties[\"*\"] : properties;\n\t\t\telse if (key !== trimmedKey) prop = key in properties ? properties[key] : properties[trimmedKey];\n\t\t\telse prop = properties[key];\n\t\t\tmessage.push(prop);\n\t\t\ti = closeIndex;\n\t\t\tstartIndex = i + 1;\n\t\t} else if (char === \"}\" && i + 1 < length && template[i + 1] === \"}\") i++;\n\t}\n\tconst remainingText = template.slice(startIndex);\n\tmessage.push(remainingText.replace(/{{/g, \"{\").replace(/}}/g, \"}\"));\n\treturn message;\n}\n/**\n* Render a message template with values.\n* @param template The message template.\n* @param values The message template values.\n* @returns The message template values interleaved between the substitution\n* values.\n*/\nfunction renderMessage(template, values) {\n\tconst args = [];\n\tfor (let i = 0; i < template.length; i++) {\n\t\targs.push(template[i]);\n\t\tif (i < values.length) args.push(values[i]);\n\t}\n\treturn args;\n}\n\n//#endregion\nexport { LoggerImpl, getLogger };\n//# sourceMappingURL=logger.js.map","//#region src/util.ts\nfunction inspect(obj, options) {\n\tconst indent = options?.compact === true ? void 0 : 2;\n\treturn JSON.stringify(obj, null, indent);\n}\n\n//#endregion\nexport { inspect };\n//# sourceMappingURL=util.js.map","import * as util from \"#util\";\n\n//#region src/formatter.ts\n/**\n* The severity level abbreviations.\n*/\nconst levelAbbreviations = {\n\t\"trace\": \"TRC\",\n\t\"debug\": \"DBG\",\n\t\"info\": \"INF\",\n\t\"warning\": \"WRN\",\n\t\"error\": \"ERR\",\n\t\"fatal\": \"FTL\"\n};\n/**\n* A platform-specific inspect function. In Deno, this is {@link Deno.inspect},\n* and in Node.js/Bun it is `util.inspect()`. If neither is available, it\n* falls back to {@link JSON.stringify}.\n*\n* @param value The value to inspect.\n* @param options The options for inspecting the value.\n* If `colors` is `true`, the output will be ANSI-colored.\n* @returns The string representation of the value.\n*/\nconst inspect = typeof document !== \"undefined\" || typeof navigator !== \"undefined\" && navigator.product === \"ReactNative\" ? (v) => JSON.stringify(v) : \"Deno\" in globalThis && \"inspect\" in globalThis.Deno && typeof globalThis.Deno.inspect === \"function\" ? (v, opts) => globalThis.Deno.inspect(v, {\n\tstrAbbreviateSize: Infinity,\n\titerableLimit: Infinity,\n\t...opts\n}) : util != null && \"inspect\" in util && typeof util.inspect === \"function\" ? (v, opts) => util.inspect(v, {\n\tmaxArrayLength: Infinity,\n\tmaxStringLength: Infinity,\n\t...opts\n}) : (v) => JSON.stringify(v);\nfunction padZero(num) {\n\treturn num < 10 ? `0${num}` : `${num}`;\n}\nfunction padThree(num) {\n\treturn num < 10 ? `00${num}` : num < 100 ? `0${num}` : `${num}`;\n}\nconst timestampFormatters = {\n\t\"date-time-timezone\": (ts) => {\n\t\tconst d = new Date(ts);\n\t\tconst year = d.getUTCFullYear();\n\t\tconst month = padZero(d.getUTCMonth() + 1);\n\t\tconst day = padZero(d.getUTCDate());\n\t\tconst hour = padZero(d.getUTCHours());\n\t\tconst minute = padZero(d.getUTCMinutes());\n\t\tconst second = padZero(d.getUTCSeconds());\n\t\tconst ms = padThree(d.getUTCMilliseconds());\n\t\treturn `${year}-${month}-${day} ${hour}:${minute}:${second}.${ms} +00:00`;\n\t},\n\t\"date-time-tz\": (ts) => {\n\t\tconst d = new Date(ts);\n\t\tconst year = d.getUTCFullYear();\n\t\tconst month = padZero(d.getUTCMonth() + 1);\n\t\tconst day = padZero(d.getUTCDate());\n\t\tconst hour = padZero(d.getUTCHours());\n\t\tconst minute = padZero(d.getUTCMinutes());\n\t\tconst second = padZero(d.getUTCSeconds());\n\t\tconst ms = padThree(d.getUTCMilliseconds());\n\t\treturn `${year}-${month}-${day} ${hour}:${minute}:${second}.${ms} +00`;\n\t},\n\t\"date-time\": (ts) => {\n\t\tconst d = new Date(ts);\n\t\tconst year = d.getUTCFullYear();\n\t\tconst month = padZero(d.getUTCMonth() + 1);\n\t\tconst day = padZero(d.getUTCDate());\n\t\tconst hour = padZero(d.getUTCHours());\n\t\tconst minute = padZero(d.getUTCMinutes());\n\t\tconst second = padZero(d.getUTCSeconds());\n\t\tconst ms = padThree(d.getUTCMilliseconds());\n\t\treturn `${year}-${month}-${day} ${hour}:${minute}:${second}.${ms}`;\n\t},\n\t\"time-timezone\": (ts) => {\n\t\tconst d = new Date(ts);\n\t\tconst hour = padZero(d.getUTCHours());\n\t\tconst minute = padZero(d.getUTCMinutes());\n\t\tconst second = padZero(d.getUTCSeconds());\n\t\tconst ms = padThree(d.getUTCMilliseconds());\n\t\treturn `${hour}:${minute}:${second}.${ms} +00:00`;\n\t},\n\t\"time-tz\": (ts) => {\n\t\tconst d = new Date(ts);\n\t\tconst hour = padZero(d.getUTCHours());\n\t\tconst minute = padZero(d.getUTCMinutes());\n\t\tconst second = padZero(d.getUTCSeconds());\n\t\tconst ms = padThree(d.getUTCMilliseconds());\n\t\treturn `${hour}:${minute}:${second}.${ms} +00`;\n\t},\n\t\"time\": (ts) => {\n\t\tconst d = new Date(ts);\n\t\tconst hour = padZero(d.getUTCHours());\n\t\tconst minute = padZero(d.getUTCMinutes());\n\t\tconst second = padZero(d.getUTCSeconds());\n\t\tconst ms = padThree(d.getUTCMilliseconds());\n\t\treturn `${hour}:${minute}:${second}.${ms}`;\n\t},\n\t\"date\": (ts) => {\n\t\tconst d = new Date(ts);\n\t\tconst year = d.getUTCFullYear();\n\t\tconst month = padZero(d.getUTCMonth() + 1);\n\t\tconst day = padZero(d.getUTCDate());\n\t\treturn `${year}-${month}-${day}`;\n\t},\n\t\"rfc3339\": (ts) => new Date(ts).toISOString(),\n\t\"none\": () => null\n};\nconst levelRenderersCache = {\n\tABBR: levelAbbreviations,\n\tabbr: {\n\t\ttrace: \"trc\",\n\t\tdebug: \"dbg\",\n\t\tinfo: \"inf\",\n\t\twarning: \"wrn\",\n\t\terror: \"err\",\n\t\tfatal: \"ftl\"\n\t},\n\tFULL: {\n\t\ttrace: \"TRACE\",\n\t\tdebug: \"DEBUG\",\n\t\tinfo: \"INFO\",\n\t\twarning: \"WARNING\",\n\t\terror: \"ERROR\",\n\t\tfatal: \"FATAL\"\n\t},\n\tfull: {\n\t\ttrace: \"trace\",\n\t\tdebug: \"debug\",\n\t\tinfo: \"info\",\n\t\twarning: \"warning\",\n\t\terror: \"error\",\n\t\tfatal: \"fatal\"\n\t},\n\tL: {\n\t\ttrace: \"T\",\n\t\tdebug: \"D\",\n\t\tinfo: \"I\",\n\t\twarning: \"W\",\n\t\terror: \"E\",\n\t\tfatal: \"F\"\n\t},\n\tl: {\n\t\ttrace: \"t\",\n\t\tdebug: \"d\",\n\t\tinfo: \"i\",\n\t\twarning: \"w\",\n\t\terror: \"e\",\n\t\tfatal: \"f\"\n\t}\n};\n/**\n* Get a text formatter with the specified options. Although it's flexible\n* enough to create a custom formatter, if you want more control, you can\n* create a custom formatter that satisfies the {@link TextFormatter} type\n* instead.\n*\n* For more information on the options, see {@link TextFormatterOptions}.\n*\n* By default, the formatter formats log records as follows:\n*\n* ```\n* 2023-11-14 22:13:20.000 +00:00 [INF] category·subcategory: Hello, world!\n* ```\n* @param options The options for the text formatter.\n* @returns The text formatter.\n* @since 0.6.0\n*/\nfunction getTextFormatter(options = {}) {\n\tconst timestampRenderer = (() => {\n\t\tconst tsOption = options.timestamp;\n\t\tif (tsOption == null) return timestampFormatters[\"date-time-timezone\"];\n\t\telse if (tsOption === \"disabled\") return timestampFormatters[\"none\"];\n\t\telse if (typeof tsOption === \"string\" && tsOption in timestampFormatters) return timestampFormatters[tsOption];\n\t\telse return tsOption;\n\t})();\n\tconst categorySeparator = options.category ?? \"·\";\n\tconst valueRenderer = options.value ?? inspect;\n\tconst levelRenderer = (() => {\n\t\tconst levelOption = options.level;\n\t\tif (levelOption == null || levelOption === \"ABBR\") return (level) => levelRenderersCache.ABBR[level];\n\t\telse if (levelOption === \"abbr\") return (level) => levelRenderersCache.abbr[level];\n\t\telse if (levelOption === \"FULL\") return (level) => levelRenderersCache.FULL[level];\n\t\telse if (levelOption === \"full\") return (level) => levelRenderersCache.full[level];\n\t\telse if (levelOption === \"L\") return (level) => levelRenderersCache.L[level];\n\t\telse if (levelOption === \"l\") return (level) => levelRenderersCache.l[level];\n\t\telse return levelOption;\n\t})();\n\tconst formatter = options.format ?? (({ timestamp, level, category, message }) => `${timestamp ? `${timestamp} ` : \"\"}[${level}] ${category}: ${message}`);\n\treturn (record) => {\n\t\tconst msgParts = record.message;\n\t\tconst msgLen = msgParts.length;\n\t\tlet message;\n\t\tif (msgLen === 1) message = msgParts[0];\n\t\telse if (msgLen <= 6) {\n\t\t\tmessage = \"\";\n\t\t\tfor (let i = 0; i < msgLen; i++) message += i % 2 === 0 ? msgParts[i] : valueRenderer(msgParts[i]);\n\t\t} else {\n\t\t\tconst parts = new Array(msgLen);\n\t\t\tfor (let i = 0; i < msgLen; i++) parts[i] = i % 2 === 0 ? msgParts[i] : valueRenderer(msgParts[i]);\n\t\t\tmessage = parts.join(\"\");\n\t\t}\n\t\tconst timestamp = timestampRenderer(record.timestamp);\n\t\tconst level = levelRenderer(record.level);\n\t\tconst category = typeof categorySeparator === \"function\" ? categorySeparator(record.category) : record.category.join(categorySeparator);\n\t\tconst values = {\n\t\t\ttimestamp,\n\t\t\tlevel,\n\t\t\tcategory,\n\t\t\tmessage,\n\t\t\trecord\n\t\t};\n\t\treturn `${formatter(values)}\\n`;\n\t};\n}\n/**\n* The default text formatter. This formatter formats log records as follows:\n*\n* ```\n* 2023-11-14 22:13:20.000 +00:00 [INF] category·subcategory: Hello, world!\n* ```\n*\n* @param record The log record to format.\n* @returns The formatted log record.\n*/\nconst defaultTextFormatter = getTextFormatter();\nconst RESET = \"\\x1B[0m\";\nconst ansiColors = {\n\tblack: \"\\x1B[30m\",\n\tred: \"\\x1B[31m\",\n\tgreen: \"\\x1B[32m\",\n\tyellow: \"\\x1B[33m\",\n\tblue: \"\\x1B[34m\",\n\tmagenta: \"\\x1B[35m\",\n\tcyan: \"\\x1B[36m\",\n\twhite: \"\\x1B[37m\"\n};\nconst ansiStyles = {\n\tbold: \"\\x1B[1m\",\n\tdim: \"\\x1B[2m\",\n\titalic: \"\\x1B[3m\",\n\tunderline: \"\\x1B[4m\",\n\tstrikethrough: \"\\x1B[9m\"\n};\nconst defaultLevelColors = {\n\ttrace: null,\n\tdebug: \"blue\",\n\tinfo: \"green\",\n\twarning: \"yellow\",\n\terror: \"red\",\n\tfatal: \"magenta\"\n};\n/**\n* Get an ANSI color formatter with the specified options.\n*\n* ![A preview of an ANSI color formatter.](https://i.imgur.com/I8LlBUf.png)\n* @param option The options for the ANSI color formatter.\n* @returns The ANSI color formatter.\n* @since 0.6.0\n*/\nfunction getAnsiColorFormatter(options = {}) {\n\tconst format = options.format;\n\tconst timestampStyle = typeof options.timestampStyle === \"undefined\" ? \"dim\" : options.timestampStyle;\n\tconst timestampColor = options.timestampColor ?? null;\n\tconst timestampPrefix = `${timestampStyle == null ? \"\" : ansiStyles[timestampStyle]}${timestampColor == null ? \"\" : ansiColors[timestampColor]}`;\n\tconst timestampSuffix = timestampStyle == null && timestampColor == null ? \"\" : RESET;\n\tconst levelStyle = typeof options.levelStyle === \"undefined\" ? \"bold\" : options.levelStyle;\n\tconst levelColors = options.levelColors ?? defaultLevelColors;\n\tconst categoryStyle = typeof options.categoryStyle === \"undefined\" ? \"dim\" : options.categoryStyle;\n\tconst categoryColor = options.categoryColor ?? null;\n\tconst categoryPrefix = `${categoryStyle == null ? \"\" : ansiStyles[categoryStyle]}${categoryColor == null ? \"\" : ansiColors[categoryColor]}`;\n\tconst categorySuffix = categoryStyle == null && categoryColor == null ? \"\" : RESET;\n\treturn getTextFormatter({\n\t\ttimestamp: \"date-time-tz\",\n\t\tvalue(value) {\n\t\t\treturn inspect(value, { colors: true });\n\t\t},\n\t\t...options,\n\t\tformat({ timestamp, level, category, message, record }) {\n\t\t\tconst levelColor = levelColors[record.level];\n\t\t\ttimestamp = `${timestampPrefix}${timestamp}${timestampSuffix}`;\n\t\t\tlevel = `${levelStyle == null ? \"\" : ansiStyles[levelStyle]}${levelColor == null ? \"\" : ansiColors[levelColor]}${level}${levelStyle == null && levelColor == null ? \"\" : RESET}`;\n\t\t\treturn format == null ? `${timestamp} ${level} ${categoryPrefix}${category}:${categorySuffix} ${message}` : format({\n\t\t\t\ttimestamp,\n\t\t\t\tlevel,\n\t\t\t\tcategory: `${categoryPrefix}${category}${categorySuffix}`,\n\t\t\t\tmessage,\n\t\t\t\trecord\n\t\t\t});\n\t\t}\n\t});\n}\n/**\n* A text formatter that uses ANSI colors to format log records.\n*\n* ![A preview of ansiColorFormatter.](https://i.imgur.com/I8LlBUf.png)\n*\n* @param record The log record to format.\n* @returns The formatted log record.\n* @since 0.5.0\n*/\nconst ansiColorFormatter = getAnsiColorFormatter();\n/**\n* Get a [JSON Lines] formatter with the specified options. The log records\n* will be rendered as JSON objects, one per line, which is a common format\n* for log files. This format is also known as Newline-Delimited JSON (NDJSON).\n* It looks like this:\n*\n* ```json\n* {\"@timestamp\":\"2023-11-14T22:13:20.000Z\",\"level\":\"INFO\",\"message\":\"Hello, world!\",\"logger\":\"my.logger\",\"properties\":{\"key\":\"value\"}}\n* ```\n*\n* [JSON Lines]: https://jsonlines.org/\n* @param options The options for the JSON Lines formatter.\n* @returns The JSON Lines formatter.\n* @since 0.11.0\n*/\nfunction getJsonLinesFormatter(options = {}) {\n\tif (!options.categorySeparator && !options.message && !options.properties) return (record) => {\n\t\tif (record.message.length === 3) return JSON.stringify({\n\t\t\t\"@timestamp\": new Date(record.timestamp).toISOString(),\n\t\t\tlevel: record.level === \"warning\" ? \"WARN\" : record.level.toUpperCase(),\n\t\t\tmessage: record.message[0] + JSON.stringify(record.message[1]) + record.message[2],\n\t\t\tlogger: record.category.join(\".\"),\n\t\t\tproperties: record.properties\n\t\t}) + \"\\n\";\n\t\tif (record.message.length === 1) return JSON.stringify({\n\t\t\t\"@timestamp\": new Date(record.timestamp).toISOString(),\n\t\t\tlevel: record.level === \"warning\" ? \"WARN\" : record.level.toUpperCase(),\n\t\t\tmessage: record.message[0],\n\t\t\tlogger: record.category.join(\".\"),\n\t\t\tproperties: record.properties\n\t\t}) + \"\\n\";\n\t\tlet msg = record.message[0];\n\t\tfor (let i = 1; i < record.message.length; i++) msg += i & 1 ? JSON.stringify(record.message[i]) : record.message[i];\n\t\treturn JSON.stringify({\n\t\t\t\"@timestamp\": new Date(record.timestamp).toISOString(),\n\t\t\tlevel: record.level === \"warning\" ? \"WARN\" : record.level.toUpperCase(),\n\t\t\tmessage: msg,\n\t\t\tlogger: record.category.join(\".\"),\n\t\t\tproperties: record.properties\n\t\t}) + \"\\n\";\n\t};\n\tconst isTemplateMessage = options.message === \"template\";\n\tconst propertiesOption = options.properties ?? \"nest:properties\";\n\tlet joinCategory;\n\tif (typeof options.categorySeparator === \"function\") joinCategory = options.categorySeparator;\n\telse {\n\t\tconst separator = options.categorySeparator ?? \".\";\n\t\tjoinCategory = (category) => category.join(separator);\n\t}\n\tlet getProperties;\n\tif (propertiesOption === \"flatten\") getProperties = (properties) => properties;\n\telse if (propertiesOption.startsWith(\"prepend:\")) {\n\t\tconst prefix = propertiesOption.substring(8);\n\t\tif (prefix === \"\") throw new TypeError(`Invalid properties option: ${JSON.stringify(propertiesOption)}. It must be of the form \"prepend:\" where is a non-empty string.`);\n\t\tgetProperties = (properties) => {\n\t\t\tconst result = {};\n\t\t\tfor (const key in properties) result[`${prefix}${key}`] = properties[key];\n\t\t\treturn result;\n\t\t};\n\t} else if (propertiesOption.startsWith(\"nest:\")) {\n\t\tconst key = propertiesOption.substring(5);\n\t\tgetProperties = (properties) => ({ [key]: properties });\n\t} else throw new TypeError(`Invalid properties option: ${JSON.stringify(propertiesOption)}. It must be \"flatten\", \"prepend:\", or \"nest:\".`);\n\tlet getMessage;\n\tif (isTemplateMessage) getMessage = (record) => {\n\t\tif (typeof record.rawMessage === \"string\") return record.rawMessage;\n\t\tlet msg = \"\";\n\t\tfor (let i = 0; i < record.rawMessage.length; i++) msg += i % 2 < 1 ? record.rawMessage[i] : \"{}\";\n\t\treturn msg;\n\t};\n\telse getMessage = (record) => {\n\t\tconst msgLen = record.message.length;\n\t\tif (msgLen === 1) return record.message[0];\n\t\tlet msg = \"\";\n\t\tfor (let i = 0; i < msgLen; i++) msg += i % 2 < 1 ? record.message[i] : JSON.stringify(record.message[i]);\n\t\treturn msg;\n\t};\n\treturn (record) => {\n\t\treturn JSON.stringify({\n\t\t\t\"@timestamp\": new Date(record.timestamp).toISOString(),\n\t\t\tlevel: record.level === \"warning\" ? \"WARN\" : record.level.toUpperCase(),\n\t\t\tmessage: getMessage(record),\n\t\t\tlogger: joinCategory(record.category),\n\t\t\t...getProperties(record.properties)\n\t\t}) + \"\\n\";\n\t};\n}\n/**\n* The default [JSON Lines] formatter. This formatter formats log records\n* as JSON objects, one per line, which is a common format for log files.\n* It looks like this:\n*\n* ```json\n* {\"@timestamp\":\"2023-11-14T22:13:20.000Z\",\"level\":\"INFO\",\"message\":\"Hello, world!\",\"logger\":\"my.logger\",\"properties\":{\"key\":\"value\"}}\n* ```\n*\n* You can customize the output by passing options to\n* {@link getJsonLinesFormatter}. For example, you can change the category\n* separator, the message format, and how the properties are formatted.\n*\n* [JSON Lines]: https://jsonlines.org/\n* @since 0.11.0\n*/\nconst jsonLinesFormatter = getJsonLinesFormatter();\n/**\n* The styles for the log level in the console.\n*/\nconst logLevelStyles = {\n\t\"trace\": \"background-color: gray; color: white;\",\n\t\"debug\": \"background-color: gray; color: white;\",\n\t\"info\": \"background-color: white; color: black;\",\n\t\"warning\": \"background-color: orange; color: black;\",\n\t\"error\": \"background-color: red; color: white;\",\n\t\"fatal\": \"background-color: maroon; color: white;\"\n};\n/**\n* The default console formatter.\n*\n* @param record The log record to format.\n* @returns The formatted log record, as an array of arguments for\n* {@link console.log}.\n*/\nfunction defaultConsoleFormatter(record) {\n\tlet msg = \"\";\n\tconst values = [];\n\tfor (let i = 0; i < record.message.length; i++) if (i % 2 === 0) msg += record.message[i];\n\telse {\n\t\tmsg += \"%o\";\n\t\tvalues.push(record.message[i]);\n\t}\n\tconst date = new Date(record.timestamp);\n\tconst time = `${date.getUTCHours().toString().padStart(2, \"0\")}:${date.getUTCMinutes().toString().padStart(2, \"0\")}:${date.getUTCSeconds().toString().padStart(2, \"0\")}.${date.getUTCMilliseconds().toString().padStart(3, \"0\")}`;\n\treturn [\n\t\t`%c${time} %c${levelAbbreviations[record.level]}%c %c${record.category.join(\"·\")} %c${msg}`,\n\t\t\"color: gray;\",\n\t\tlogLevelStyles[record.level],\n\t\t\"background-color: default;\",\n\t\t\"color: gray;\",\n\t\t\"color: default;\",\n\t\t...values\n\t];\n}\n\n//#endregion\nexport { ansiColorFormatter, defaultConsoleFormatter, defaultTextFormatter, getAnsiColorFormatter, getJsonLinesFormatter, getTextFormatter, jsonLinesFormatter };\n//# sourceMappingURL=formatter.js.map","import { toFilter } from \"./filter.js\";\nimport { compareLogLevel } from \"./level.js\";\nimport { defaultConsoleFormatter, defaultTextFormatter } from \"./formatter.js\";\n\n//#region src/sink.ts\n/**\n* Turns a sink into a filtered sink. The returned sink only logs records that\n* pass the filter.\n*\n* @example Filter a console sink to only log records with the info level\n* ```typescript\n* const sink = withFilter(getConsoleSink(), \"info\");\n* ```\n*\n* @param sink A sink to be filtered.\n* @param filter A filter to apply to the sink. It can be either a filter\n* function or a {@link LogLevel} string.\n* @returns A sink that only logs records that pass the filter.\n*/\nfunction withFilter(sink, filter) {\n\tconst filterFunc = toFilter(filter);\n\treturn (record) => {\n\t\tif (filterFunc(record)) sink(record);\n\t};\n}\n/**\n* A factory that returns a sink that writes to a {@link WritableStream}.\n*\n* Note that the `stream` is of Web Streams API, which is different from\n* Node.js streams. You can convert a Node.js stream to a Web Streams API\n* stream using [`stream.Writable.toWeb()`] method.\n*\n* [`stream.Writable.toWeb()`]: https://nodejs.org/api/stream.html#streamwritabletowebstreamwritable\n*\n* @example Sink to the standard error in Deno\n* ```typescript\n* const stderrSink = getStreamSink(Deno.stderr.writable);\n* ```\n*\n* @example Sink to the standard error in Node.js\n* ```typescript\n* import stream from \"node:stream\";\n* const stderrSink = getStreamSink(stream.Writable.toWeb(process.stderr));\n* ```\n*\n* @param stream The stream to write to.\n* @param options The options for the sink.\n* @returns A sink that writes to the stream.\n*/\nfunction getStreamSink(stream, options = {}) {\n\tconst formatter = options.formatter ?? defaultTextFormatter;\n\tconst encoder = options.encoder ?? new TextEncoder();\n\tconst writer = stream.getWriter();\n\tif (!options.nonBlocking) {\n\t\tlet lastPromise = Promise.resolve();\n\t\tconst sink = (record) => {\n\t\t\tconst bytes = encoder.encode(formatter(record));\n\t\t\tlastPromise = lastPromise.then(() => writer.ready).then(() => writer.write(bytes));\n\t\t};\n\t\tsink[Symbol.asyncDispose] = async () => {\n\t\t\tawait lastPromise;\n\t\t\tawait writer.close();\n\t\t};\n\t\treturn sink;\n\t}\n\tconst nonBlockingConfig = options.nonBlocking === true ? {} : options.nonBlocking;\n\tconst bufferSize = nonBlockingConfig.bufferSize ?? 100;\n\tconst flushInterval = nonBlockingConfig.flushInterval ?? 100;\n\tconst buffer = [];\n\tlet flushTimer = null;\n\tlet disposed = false;\n\tlet activeFlush = null;\n\tconst maxBufferSize = bufferSize * 2;\n\tasync function flush() {\n\t\tif (buffer.length === 0) return;\n\t\tconst records = buffer.splice(0);\n\t\tfor (const record of records) try {\n\t\t\tconst bytes = encoder.encode(formatter(record));\n\t\t\tawait writer.ready;\n\t\t\tawait writer.write(bytes);\n\t\t} catch {}\n\t}\n\tfunction scheduleFlush() {\n\t\tif (activeFlush) return;\n\t\tactiveFlush = flush().finally(() => {\n\t\t\tactiveFlush = null;\n\t\t});\n\t}\n\tfunction startFlushTimer() {\n\t\tif (flushTimer !== null || disposed) return;\n\t\tflushTimer = setInterval(() => {\n\t\t\tscheduleFlush();\n\t\t}, flushInterval);\n\t}\n\tconst nonBlockingSink = (record) => {\n\t\tif (disposed) return;\n\t\tif (buffer.length >= maxBufferSize) buffer.shift();\n\t\tbuffer.push(record);\n\t\tif (buffer.length >= bufferSize) scheduleFlush();\n\t\telse if (flushTimer === null) startFlushTimer();\n\t};\n\tnonBlockingSink[Symbol.asyncDispose] = async () => {\n\t\tdisposed = true;\n\t\tif (flushTimer !== null) {\n\t\t\tclearInterval(flushTimer);\n\t\t\tflushTimer = null;\n\t\t}\n\t\tawait flush();\n\t\ttry {\n\t\t\tawait writer.close();\n\t\t} catch {}\n\t};\n\treturn nonBlockingSink;\n}\n/**\n* A console sink factory that returns a sink that logs to the console.\n*\n* @param options The options for the sink.\n* @returns A sink that logs to the console. If `nonBlocking` is enabled,\n* returns a sink that also implements {@link Disposable}.\n*/\nfunction getConsoleSink(options = {}) {\n\tconst formatter = options.formatter ?? defaultConsoleFormatter;\n\tconst levelMap = {\n\t\ttrace: \"debug\",\n\t\tdebug: \"debug\",\n\t\tinfo: \"info\",\n\t\twarning: \"warn\",\n\t\terror: \"error\",\n\t\tfatal: \"error\",\n\t\t...options.levelMap ?? {}\n\t};\n\tconst console = options.console ?? globalThis.console;\n\tconst baseSink = (record) => {\n\t\tconst args = formatter(record);\n\t\tconst method = levelMap[record.level];\n\t\tif (method === void 0) throw new TypeError(`Invalid log level: ${record.level}.`);\n\t\tif (typeof args === \"string\") {\n\t\t\tconst msg = args.replace(/\\r?\\n$/, \"\");\n\t\t\tconsole[method](msg);\n\t\t} else console[method](...args);\n\t};\n\tif (!options.nonBlocking) return baseSink;\n\tconst nonBlockingConfig = options.nonBlocking === true ? {} : options.nonBlocking;\n\tconst bufferSize = nonBlockingConfig.bufferSize ?? 100;\n\tconst flushInterval = nonBlockingConfig.flushInterval ?? 100;\n\tconst buffer = [];\n\tlet flushTimer = null;\n\tlet disposed = false;\n\tlet flushScheduled = false;\n\tconst maxBufferSize = bufferSize * 2;\n\tfunction flush() {\n\t\tif (buffer.length === 0) return;\n\t\tconst records = buffer.splice(0);\n\t\tfor (const record of records) try {\n\t\t\tbaseSink(record);\n\t\t} catch {}\n\t}\n\tfunction scheduleFlush() {\n\t\tif (flushScheduled) return;\n\t\tflushScheduled = true;\n\t\tsetTimeout(() => {\n\t\t\tflushScheduled = false;\n\t\t\tflush();\n\t\t}, 0);\n\t}\n\tfunction startFlushTimer() {\n\t\tif (flushTimer !== null || disposed) return;\n\t\tflushTimer = setInterval(() => {\n\t\t\tflush();\n\t\t}, flushInterval);\n\t}\n\tconst nonBlockingSink = (record) => {\n\t\tif (disposed) return;\n\t\tif (buffer.length >= maxBufferSize) buffer.shift();\n\t\tbuffer.push(record);\n\t\tif (buffer.length >= bufferSize) scheduleFlush();\n\t\telse if (flushTimer === null) startFlushTimer();\n\t};\n\tnonBlockingSink[Symbol.dispose] = () => {\n\t\tdisposed = true;\n\t\tif (flushTimer !== null) {\n\t\t\tclearInterval(flushTimer);\n\t\t\tflushTimer = null;\n\t\t}\n\t\tflush();\n\t};\n\treturn nonBlockingSink;\n}\n/**\n* Converts an async sink into a regular sink with proper async handling.\n* The returned sink chains async operations to ensure proper ordering and\n* implements AsyncDisposable to wait for all pending operations on disposal.\n*\n* @example Create a sink that asynchronously posts to a webhook\n* ```typescript\n* const asyncSink: AsyncSink = async (record) => {\n* await fetch(\"https://example.com/logs\", {\n* method: \"POST\",\n* body: JSON.stringify(record),\n* });\n* };\n* const sink = fromAsyncSink(asyncSink);\n* ```\n*\n* @param asyncSink The async sink function to convert.\n* @returns A sink that properly handles async operations and disposal.\n* @since 1.0.0\n*/\nfunction fromAsyncSink(asyncSink) {\n\tlet lastPromise = Promise.resolve();\n\tconst sink = (record) => {\n\t\tlastPromise = lastPromise.then(() => asyncSink(record)).catch(() => {});\n\t};\n\tsink[Symbol.asyncDispose] = async () => {\n\t\tawait lastPromise;\n\t};\n\treturn sink;\n}\n/**\n* Creates a sink that buffers log records until a trigger level is reached.\n* This pattern, known as \"fingers crossed\" logging, keeps detailed debug logs\n* in memory and only outputs them when an error or other significant event occurs.\n*\n* @example Basic usage with default settings\n* ```typescript\n* const sink = fingersCrossed(getConsoleSink());\n* // Debug and info logs are buffered\n* // When an error occurs, all buffered logs + the error are output\n* ```\n*\n* @example Custom trigger level and buffer size\n* ```typescript\n* const sink = fingersCrossed(getConsoleSink(), {\n* triggerLevel: \"warning\", // Trigger on warning or higher\n* maxBufferSize: 500 // Keep last 500 records\n* });\n* ```\n*\n* @example Category isolation\n* ```typescript\n* const sink = fingersCrossed(getConsoleSink(), {\n* isolateByCategory: \"descendant\" // Separate buffers per category\n* });\n* // Error in [\"app\"] triggers flush of [\"app\"] and [\"app\", \"module\"] buffers\n* // But not [\"other\"] buffer\n* ```\n*\n* @param sink The sink to wrap. Buffered records are sent to this sink when\n* triggered.\n* @param options Configuration options for the fingers crossed behavior.\n* @returns A sink that buffers records until the trigger level is reached.\n* @since 1.1.0\n*/\nfunction fingersCrossed(sink, options = {}) {\n\tconst triggerLevel = options.triggerLevel ?? \"error\";\n\tconst maxBufferSize = Math.max(0, options.maxBufferSize ?? 1e3);\n\tconst isolateByCategory = options.isolateByCategory;\n\ttry {\n\t\tcompareLogLevel(\"trace\", triggerLevel);\n\t} catch (error) {\n\t\tthrow new TypeError(`Invalid triggerLevel: ${JSON.stringify(triggerLevel)}. ${error instanceof Error ? error.message : String(error)}`);\n\t}\n\tfunction isDescendant(parent, child) {\n\t\tif (parent.length === 0 || child.length === 0) return false;\n\t\tif (parent.length > child.length) return false;\n\t\treturn parent.every((p, i) => p === child[i]);\n\t}\n\tfunction isAncestor(child, parent) {\n\t\tif (child.length === 0 || parent.length === 0) return false;\n\t\tif (child.length < parent.length) return false;\n\t\treturn parent.every((p, i) => p === child[i]);\n\t}\n\tlet shouldFlushBuffer = null;\n\tif (isolateByCategory) if (typeof isolateByCategory === \"function\") shouldFlushBuffer = isolateByCategory;\n\telse switch (isolateByCategory) {\n\t\tcase \"descendant\":\n\t\t\tshouldFlushBuffer = (trigger, buffered) => isDescendant(trigger, buffered);\n\t\t\tbreak;\n\t\tcase \"ancestor\":\n\t\t\tshouldFlushBuffer = (trigger, buffered) => isAncestor(trigger, buffered);\n\t\t\tbreak;\n\t\tcase \"both\":\n\t\t\tshouldFlushBuffer = (trigger, buffered) => isDescendant(trigger, buffered) || isAncestor(trigger, buffered);\n\t\t\tbreak;\n\t}\n\tfunction getCategoryKey(category) {\n\t\treturn JSON.stringify(category);\n\t}\n\tfunction parseCategoryKey(key) {\n\t\treturn JSON.parse(key);\n\t}\n\tif (!isolateByCategory) {\n\t\tconst buffer = [];\n\t\tlet triggered = false;\n\t\treturn (record) => {\n\t\t\tif (triggered) {\n\t\t\t\tsink(record);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (compareLogLevel(record.level, triggerLevel) >= 0) {\n\t\t\t\ttriggered = true;\n\t\t\t\tfor (const bufferedRecord of buffer) sink(bufferedRecord);\n\t\t\t\tbuffer.length = 0;\n\t\t\t\tsink(record);\n\t\t\t} else {\n\t\t\t\tbuffer.push(record);\n\t\t\t\twhile (buffer.length > maxBufferSize) buffer.shift();\n\t\t\t}\n\t\t};\n\t} else {\n\t\tconst buffers = /* @__PURE__ */ new Map();\n\t\tconst triggered = /* @__PURE__ */ new Set();\n\t\treturn (record) => {\n\t\t\tconst categoryKey = getCategoryKey(record.category);\n\t\t\tif (triggered.has(categoryKey)) {\n\t\t\t\tsink(record);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (compareLogLevel(record.level, triggerLevel) >= 0) {\n\t\t\t\tconst keysToFlush = /* @__PURE__ */ new Set();\n\t\t\t\tfor (const [bufferedKey] of buffers) if (bufferedKey === categoryKey) keysToFlush.add(bufferedKey);\n\t\t\t\telse if (shouldFlushBuffer) {\n\t\t\t\t\tconst bufferedCategory = parseCategoryKey(bufferedKey);\n\t\t\t\t\ttry {\n\t\t\t\t\t\tif (shouldFlushBuffer(record.category, bufferedCategory)) keysToFlush.add(bufferedKey);\n\t\t\t\t\t} catch {}\n\t\t\t\t}\n\t\t\t\tconst allRecordsToFlush = [];\n\t\t\t\tfor (const key of keysToFlush) {\n\t\t\t\t\tconst buffer = buffers.get(key);\n\t\t\t\t\tif (buffer) {\n\t\t\t\t\t\tallRecordsToFlush.push(...buffer);\n\t\t\t\t\t\tbuffers.delete(key);\n\t\t\t\t\t\ttriggered.add(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tallRecordsToFlush.sort((a, b) => a.timestamp - b.timestamp);\n\t\t\t\tfor (const bufferedRecord of allRecordsToFlush) sink(bufferedRecord);\n\t\t\t\ttriggered.add(categoryKey);\n\t\t\t\tsink(record);\n\t\t\t} else {\n\t\t\t\tlet buffer = buffers.get(categoryKey);\n\t\t\t\tif (!buffer) {\n\t\t\t\t\tbuffer = [];\n\t\t\t\t\tbuffers.set(categoryKey, buffer);\n\t\t\t\t}\n\t\t\t\tbuffer.push(record);\n\t\t\t\twhile (buffer.length > maxBufferSize) buffer.shift();\n\t\t\t}\n\t\t};\n\t}\n}\n\n//#endregion\nexport { fingersCrossed, fromAsyncSink, getConsoleSink, getStreamSink, withFilter };\n//# sourceMappingURL=sink.js.map","import { toFilter } from \"./filter.js\";\nimport { LoggerImpl } from \"./logger.js\";\nimport { getConsoleSink } from \"./sink.js\";\n\n//#region src/config.ts\n/**\n* The current configuration, if any. Otherwise, `null`.\n*/\nlet currentConfig = null;\n/**\n* Strong references to the loggers.\n* This is to prevent the loggers from being garbage collected so that their\n* sinks and filters are not removed.\n*/\nconst strongRefs = /* @__PURE__ */ new Set();\n/**\n* Disposables to dispose when resetting the configuration.\n*/\nconst disposables = /* @__PURE__ */ new Set();\n/**\n* Async disposables to dispose when resetting the configuration.\n*/\nconst asyncDisposables = /* @__PURE__ */ new Set();\n/**\n* Check if a config is for the meta logger.\n*/\nfunction isLoggerConfigMeta(cfg) {\n\treturn cfg.category.length === 0 || cfg.category.length === 1 && cfg.category[0] === \"logtape\" || cfg.category.length === 2 && cfg.category[0] === \"logtape\" && cfg.category[1] === \"meta\";\n}\n/**\n* Configure the loggers with the specified configuration.\n*\n* Note that if the given sinks or filters are disposable, they will be\n* disposed when the configuration is reset, or when the process exits.\n*\n* @example\n* ```typescript\n* await configure({\n* sinks: {\n* console: getConsoleSink(),\n* },\n* filters: {\n* slow: (log) =>\n* \"duration\" in log.properties &&\n* log.properties.duration as number > 1000,\n* },\n* loggers: [\n* {\n* category: \"my-app\",\n* sinks: [\"console\"],\n* lowestLevel: \"info\",\n* },\n* {\n* category: [\"my-app\", \"sql\"],\n* filters: [\"slow\"],\n* lowestLevel: \"debug\",\n* },\n* {\n* category: \"logtape\",\n* sinks: [\"console\"],\n* lowestLevel: \"error\",\n* },\n* ],\n* });\n* ```\n*\n* @param config The configuration.\n*/\nasync function configure(config) {\n\tif (currentConfig != null && !config.reset) throw new ConfigError(\"Already configured; if you want to reset, turn on the reset flag.\");\n\tawait reset();\n\ttry {\n\t\tconfigureInternal(config, true);\n\t} catch (e) {\n\t\tif (e instanceof ConfigError) await reset();\n\t\tthrow e;\n\t}\n}\n/**\n* Configure sync loggers with the specified configuration.\n*\n* Note that if the given sinks or filters are disposable, they will be\n* disposed when the configuration is reset, or when the process exits.\n*\n* Also note that passing async sinks or filters will throw. If\n* necessary use {@link resetSync} or {@link disposeSync}.\n*\n* @example\n* ```typescript\n* configureSync({\n* sinks: {\n* console: getConsoleSink(),\n* },\n* loggers: [\n* {\n* category: \"my-app\",\n* sinks: [\"console\"],\n* lowestLevel: \"info\",\n* },\n* {\n* category: \"logtape\",\n* sinks: [\"console\"],\n* lowestLevel: \"error\",\n* },\n* ],\n* });\n* ```\n*\n* @param config The configuration.\n* @since 0.9.0\n*/\nfunction configureSync(config) {\n\tif (currentConfig != null && !config.reset) throw new ConfigError(\"Already configured; if you want to reset, turn on the reset flag.\");\n\tif (asyncDisposables.size > 0) throw new ConfigError(\"Previously configured async disposables are still active. Use configure() instead or explicitly dispose them using dispose().\");\n\tresetSync();\n\ttry {\n\t\tconfigureInternal(config, false);\n\t} catch (e) {\n\t\tif (e instanceof ConfigError) resetSync();\n\t\tthrow e;\n\t}\n}\nfunction configureInternal(config, allowAsync) {\n\tcurrentConfig = config;\n\tlet metaConfigured = false;\n\tconst configuredCategories = /* @__PURE__ */ new Set();\n\tfor (const cfg of config.loggers) {\n\t\tif (isLoggerConfigMeta(cfg)) metaConfigured = true;\n\t\tconst categoryKey = Array.isArray(cfg.category) ? JSON.stringify(cfg.category) : JSON.stringify([cfg.category]);\n\t\tif (configuredCategories.has(categoryKey)) throw new ConfigError(`Duplicate logger configuration for category: ${categoryKey}. Each category can only be configured once.`);\n\t\tconfiguredCategories.add(categoryKey);\n\t\tconst logger = LoggerImpl.getLogger(cfg.category);\n\t\tfor (const sinkId of cfg.sinks ?? []) {\n\t\t\tconst sink = config.sinks[sinkId];\n\t\t\tif (!sink) throw new ConfigError(`Sink not found: ${sinkId}.`);\n\t\t\tlogger.sinks.push(sink);\n\t\t}\n\t\tlogger.parentSinks = cfg.parentSinks ?? \"inherit\";\n\t\tif (cfg.lowestLevel !== void 0) logger.lowestLevel = cfg.lowestLevel;\n\t\tfor (const filterId of cfg.filters ?? []) {\n\t\t\tconst filter = config.filters?.[filterId];\n\t\t\tif (filter === void 0) throw new ConfigError(`Filter not found: ${filterId}.`);\n\t\t\tlogger.filters.push(toFilter(filter));\n\t\t}\n\t\tstrongRefs.add(logger);\n\t}\n\tLoggerImpl.getLogger().contextLocalStorage = config.contextLocalStorage;\n\tfor (const sink of Object.values(config.sinks)) {\n\t\tif (Symbol.asyncDispose in sink) if (allowAsync) asyncDisposables.add(sink);\n\t\telse throw new ConfigError(\"Async disposables cannot be used with configureSync().\");\n\t\tif (Symbol.dispose in sink) disposables.add(sink);\n\t}\n\tfor (const filter of Object.values(config.filters ?? {})) {\n\t\tif (filter == null || typeof filter === \"string\") continue;\n\t\tif (Symbol.asyncDispose in filter) if (allowAsync) asyncDisposables.add(filter);\n\t\telse throw new ConfigError(\"Async disposables cannot be used with configureSync().\");\n\t\tif (Symbol.dispose in filter) disposables.add(filter);\n\t}\n\tif (typeof globalThis.EdgeRuntime !== \"string\" && \"process\" in globalThis && !(\"Deno\" in globalThis)) {\n\t\tconst proc = globalThis.process;\n\t\tconst onMethod = proc?.[\"on\"];\n\t\tif (typeof onMethod === \"function\") onMethod.call(proc, \"exit\", allowAsync ? dispose : disposeSync);\n\t} else addEventListener(\"unload\", allowAsync ? dispose : disposeSync);\n\tconst meta = LoggerImpl.getLogger([\"logtape\", \"meta\"]);\n\tif (!metaConfigured) meta.sinks.push(getConsoleSink());\n\tmeta.info(\"LogTape loggers are configured. Note that LogTape itself uses the meta logger, which has category {metaLoggerCategory}. The meta logger purposes to log internal errors such as sink exceptions. If you are seeing this message, the meta logger is automatically configured. It's recommended to configure the meta logger with a separate sink so that you can easily notice if logging itself fails or is misconfigured. To turn off this message, configure the meta logger with higher log levels than {dismissLevel}. See also .\", {\n\t\tmetaLoggerCategory: [\"logtape\", \"meta\"],\n\t\tdismissLevel: \"info\"\n\t});\n}\n/**\n* Get the current configuration, if any. Otherwise, `null`.\n* @returns The current configuration, if any. Otherwise, `null`.\n*/\nfunction getConfig() {\n\treturn currentConfig;\n}\n/**\n* Reset the configuration. Mostly for testing purposes.\n*/\nasync function reset() {\n\tawait dispose();\n\tresetInternal();\n}\n/**\n* Reset the configuration. Mostly for testing purposes. Will not clear async\n* sinks, only use with sync sinks. Use {@link reset} if you have async sinks.\n* @since 0.9.0\n*/\nfunction resetSync() {\n\tdisposeSync();\n\tresetInternal();\n}\nfunction resetInternal() {\n\tconst rootLogger = LoggerImpl.getLogger([]);\n\trootLogger.resetDescendants();\n\tdelete rootLogger.contextLocalStorage;\n\tstrongRefs.clear();\n\tcurrentConfig = null;\n}\n/**\n* Dispose of the disposables.\n*/\nasync function dispose() {\n\tdisposeSync();\n\tconst promises = [];\n\tfor (const disposable of asyncDisposables) {\n\t\tpromises.push(disposable[Symbol.asyncDispose]());\n\t\tasyncDisposables.delete(disposable);\n\t}\n\tawait Promise.all(promises);\n}\n/**\n* Dispose of the sync disposables. Async disposables will be untouched,\n* use {@link dispose} if you have async sinks.\n* @since 0.9.0\n*/\nfunction disposeSync() {\n\tfor (const disposable of disposables) disposable[Symbol.dispose]();\n\tdisposables.clear();\n}\n/**\n* A configuration error.\n*/\nvar ConfigError = class extends Error {\n\t/**\n\t* Constructs a new configuration error.\n\t* @param message The error message.\n\t*/\n\tconstructor(message) {\n\t\tsuper(message);\n\t\tthis.name = \"ConfigureError\";\n\t}\n};\n\n//#endregion\nexport { ConfigError, configure, configureSync, dispose, disposeSync, getConfig, reset, resetSync };\n//# sourceMappingURL=config.js.map","const ANSI_BACKGROUND_OFFSET = 10;\n\nconst wrapAnsi16 = (offset = 0) => code => `\\u001B[${code + offset}m`;\n\nconst wrapAnsi256 = (offset = 0) => code => `\\u001B[${38 + offset};5;${code}m`;\n\nconst wrapAnsi16m = (offset = 0) => (red, green, blue) => `\\u001B[${38 + offset};2;${red};${green};${blue}m`;\n\nconst styles = {\n\tmodifier: {\n\t\treset: [0, 0],\n\t\t// 21 isn't widely supported and 22 does the same thing\n\t\tbold: [1, 22],\n\t\tdim: [2, 22],\n\t\titalic: [3, 23],\n\t\tunderline: [4, 24],\n\t\toverline: [53, 55],\n\t\tinverse: [7, 27],\n\t\thidden: [8, 28],\n\t\tstrikethrough: [9, 29],\n\t},\n\tcolor: {\n\t\tblack: [30, 39],\n\t\tred: [31, 39],\n\t\tgreen: [32, 39],\n\t\tyellow: [33, 39],\n\t\tblue: [34, 39],\n\t\tmagenta: [35, 39],\n\t\tcyan: [36, 39],\n\t\twhite: [37, 39],\n\n\t\t// Bright color\n\t\tblackBright: [90, 39],\n\t\tgray: [90, 39], // Alias of `blackBright`\n\t\tgrey: [90, 39], // Alias of `blackBright`\n\t\tredBright: [91, 39],\n\t\tgreenBright: [92, 39],\n\t\tyellowBright: [93, 39],\n\t\tblueBright: [94, 39],\n\t\tmagentaBright: [95, 39],\n\t\tcyanBright: [96, 39],\n\t\twhiteBright: [97, 39],\n\t},\n\tbgColor: {\n\t\tbgBlack: [40, 49],\n\t\tbgRed: [41, 49],\n\t\tbgGreen: [42, 49],\n\t\tbgYellow: [43, 49],\n\t\tbgBlue: [44, 49],\n\t\tbgMagenta: [45, 49],\n\t\tbgCyan: [46, 49],\n\t\tbgWhite: [47, 49],\n\n\t\t// Bright color\n\t\tbgBlackBright: [100, 49],\n\t\tbgGray: [100, 49], // Alias of `bgBlackBright`\n\t\tbgGrey: [100, 49], // Alias of `bgBlackBright`\n\t\tbgRedBright: [101, 49],\n\t\tbgGreenBright: [102, 49],\n\t\tbgYellowBright: [103, 49],\n\t\tbgBlueBright: [104, 49],\n\t\tbgMagentaBright: [105, 49],\n\t\tbgCyanBright: [106, 49],\n\t\tbgWhiteBright: [107, 49],\n\t},\n};\n\nexport const modifierNames = Object.keys(styles.modifier);\nexport const foregroundColorNames = Object.keys(styles.color);\nexport const backgroundColorNames = Object.keys(styles.bgColor);\nexport const colorNames = [...foregroundColorNames, ...backgroundColorNames];\n\nfunction assembleStyles() {\n\tconst codes = new Map();\n\n\tfor (const [groupName, group] of Object.entries(styles)) {\n\t\tfor (const [styleName, style] of Object.entries(group)) {\n\t\t\tstyles[styleName] = {\n\t\t\t\topen: `\\u001B[${style[0]}m`,\n\t\t\t\tclose: `\\u001B[${style[1]}m`,\n\t\t\t};\n\n\t\t\tgroup[styleName] = styles[styleName];\n\n\t\t\tcodes.set(style[0], style[1]);\n\t\t}\n\n\t\tObject.defineProperty(styles, groupName, {\n\t\t\tvalue: group,\n\t\t\tenumerable: false,\n\t\t});\n\t}\n\n\tObject.defineProperty(styles, 'codes', {\n\t\tvalue: codes,\n\t\tenumerable: false,\n\t});\n\n\tstyles.color.close = '\\u001B[39m';\n\tstyles.bgColor.close = '\\u001B[49m';\n\n\tstyles.color.ansi = wrapAnsi16();\n\tstyles.color.ansi256 = wrapAnsi256();\n\tstyles.color.ansi16m = wrapAnsi16m();\n\tstyles.bgColor.ansi = wrapAnsi16(ANSI_BACKGROUND_OFFSET);\n\tstyles.bgColor.ansi256 = wrapAnsi256(ANSI_BACKGROUND_OFFSET);\n\tstyles.bgColor.ansi16m = wrapAnsi16m(ANSI_BACKGROUND_OFFSET);\n\n\t// From https://github.com/Qix-/color-convert/blob/3f0e0d4e92e235796ccb17f6e85c72094a651f49/conversions.js\n\tObject.defineProperties(styles, {\n\t\trgbToAnsi256: {\n\t\t\tvalue(red, green, blue) {\n\t\t\t\t// We use the extended greyscale palette here, with the exception of\n\t\t\t\t// black and white. normal palette only has 4 greyscale shades.\n\t\t\t\tif (red === green && green === blue) {\n\t\t\t\t\tif (red < 8) {\n\t\t\t\t\t\treturn 16;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (red > 248) {\n\t\t\t\t\t\treturn 231;\n\t\t\t\t\t}\n\n\t\t\t\t\treturn Math.round(((red - 8) / 247) * 24) + 232;\n\t\t\t\t}\n\n\t\t\t\treturn 16\n\t\t\t\t\t+ (36 * Math.round(red / 255 * 5))\n\t\t\t\t\t+ (6 * Math.round(green / 255 * 5))\n\t\t\t\t\t+ Math.round(blue / 255 * 5);\n\t\t\t},\n\t\t\tenumerable: false,\n\t\t},\n\t\thexToRgb: {\n\t\t\tvalue(hex) {\n\t\t\t\tconst matches = /[a-f\\d]{6}|[a-f\\d]{3}/i.exec(hex.toString(16));\n\t\t\t\tif (!matches) {\n\t\t\t\t\treturn [0, 0, 0];\n\t\t\t\t}\n\n\t\t\t\tlet [colorString] = matches;\n\n\t\t\t\tif (colorString.length === 3) {\n\t\t\t\t\tcolorString = [...colorString].map(character => character + character).join('');\n\t\t\t\t}\n\n\t\t\t\tconst integer = Number.parseInt(colorString, 16);\n\n\t\t\t\treturn [\n\t\t\t\t\t/* eslint-disable no-bitwise */\n\t\t\t\t\t(integer >> 16) & 0xFF,\n\t\t\t\t\t(integer >> 8) & 0xFF,\n\t\t\t\t\tinteger & 0xFF,\n\t\t\t\t\t/* eslint-enable no-bitwise */\n\t\t\t\t];\n\t\t\t},\n\t\t\tenumerable: false,\n\t\t},\n\t\thexToAnsi256: {\n\t\t\tvalue: hex => styles.rgbToAnsi256(...styles.hexToRgb(hex)),\n\t\t\tenumerable: false,\n\t\t},\n\t\tansi256ToAnsi: {\n\t\t\tvalue(code) {\n\t\t\t\tif (code < 8) {\n\t\t\t\t\treturn 30 + code;\n\t\t\t\t}\n\n\t\t\t\tif (code < 16) {\n\t\t\t\t\treturn 90 + (code - 8);\n\t\t\t\t}\n\n\t\t\t\tlet red;\n\t\t\t\tlet green;\n\t\t\t\tlet blue;\n\n\t\t\t\tif (code >= 232) {\n\t\t\t\t\tred = (((code - 232) * 10) + 8) / 255;\n\t\t\t\t\tgreen = red;\n\t\t\t\t\tblue = red;\n\t\t\t\t} else {\n\t\t\t\t\tcode -= 16;\n\n\t\t\t\t\tconst remainder = code % 36;\n\n\t\t\t\t\tred = Math.floor(code / 36) / 5;\n\t\t\t\t\tgreen = Math.floor(remainder / 6) / 5;\n\t\t\t\t\tblue = (remainder % 6) / 5;\n\t\t\t\t}\n\n\t\t\t\tconst value = Math.max(red, green, blue) * 2;\n\n\t\t\t\tif (value === 0) {\n\t\t\t\t\treturn 30;\n\t\t\t\t}\n\n\t\t\t\t// eslint-disable-next-line no-bitwise\n\t\t\t\tlet result = 30 + ((Math.round(blue) << 2) | (Math.round(green) << 1) | Math.round(red));\n\n\t\t\t\tif (value === 2) {\n\t\t\t\t\tresult += 60;\n\t\t\t\t}\n\n\t\t\t\treturn result;\n\t\t\t},\n\t\t\tenumerable: false,\n\t\t},\n\t\trgbToAnsi: {\n\t\t\tvalue: (red, green, blue) => styles.ansi256ToAnsi(styles.rgbToAnsi256(red, green, blue)),\n\t\t\tenumerable: false,\n\t\t},\n\t\thexToAnsi: {\n\t\t\tvalue: hex => styles.ansi256ToAnsi(styles.hexToAnsi256(hex)),\n\t\t\tenumerable: false,\n\t\t},\n\t});\n\n\treturn styles;\n}\n\nconst ansiStyles = assembleStyles();\n\nexport default ansiStyles;\n","/* eslint-env browser */\n\nconst level = (() => {\n\tif (!('navigator' in globalThis)) {\n\t\treturn 0;\n\t}\n\n\tif (globalThis.navigator.userAgentData) {\n\t\tconst brand = navigator.userAgentData.brands.find(({brand}) => brand === 'Chromium');\n\t\tif (brand && brand.version > 93) {\n\t\t\treturn 3;\n\t\t}\n\t}\n\n\tif (/\\b(Chrome|Chromium)\\//.test(globalThis.navigator.userAgent)) {\n\t\treturn 1;\n\t}\n\n\treturn 0;\n})();\n\nconst colorSupport = level !== 0 && {\n\tlevel,\n\thasBasic: true,\n\thas256: level >= 2,\n\thas16m: level >= 3,\n};\n\nconst supportsColor = {\n\tstdout: colorSupport,\n\tstderr: colorSupport,\n};\n\nexport default supportsColor;\n","// TODO: When targeting Node.js 16, use `String.prototype.replaceAll`.\nexport function stringReplaceAll(string, substring, replacer) {\n\tlet index = string.indexOf(substring);\n\tif (index === -1) {\n\t\treturn string;\n\t}\n\n\tconst substringLength = substring.length;\n\tlet endIndex = 0;\n\tlet returnValue = '';\n\tdo {\n\t\treturnValue += string.slice(endIndex, index) + substring + replacer;\n\t\tendIndex = index + substringLength;\n\t\tindex = string.indexOf(substring, endIndex);\n\t} while (index !== -1);\n\n\treturnValue += string.slice(endIndex);\n\treturn returnValue;\n}\n\nexport function stringEncaseCRLFWithFirstIndex(string, prefix, postfix, index) {\n\tlet endIndex = 0;\n\tlet returnValue = '';\n\tdo {\n\t\tconst gotCR = string[index - 1] === '\\r';\n\t\treturnValue += string.slice(endIndex, (gotCR ? index - 1 : index)) + prefix + (gotCR ? '\\r\\n' : '\\n') + postfix;\n\t\tendIndex = index + 1;\n\t\tindex = string.indexOf('\\n', endIndex);\n\t} while (index !== -1);\n\n\treturnValue += string.slice(endIndex);\n\treturn returnValue;\n}\n","import ansiStyles from '#ansi-styles';\nimport supportsColor from '#supports-color';\nimport { // eslint-disable-line import/order\n\tstringReplaceAll,\n\tstringEncaseCRLFWithFirstIndex,\n} from './utilities.js';\n\nconst {stdout: stdoutColor, stderr: stderrColor} = supportsColor;\n\nconst GENERATOR = Symbol('GENERATOR');\nconst STYLER = Symbol('STYLER');\nconst IS_EMPTY = Symbol('IS_EMPTY');\n\n// `supportsColor.level` → `ansiStyles.color[name]` mapping\nconst levelMapping = [\n\t'ansi',\n\t'ansi',\n\t'ansi256',\n\t'ansi16m',\n];\n\nconst styles = Object.create(null);\n\nconst applyOptions = (object, options = {}) => {\n\tif (options.level && !(Number.isInteger(options.level) && options.level >= 0 && options.level <= 3)) {\n\t\tthrow new Error('The `level` option should be an integer from 0 to 3');\n\t}\n\n\t// Detect level if not set manually\n\tconst colorLevel = stdoutColor ? stdoutColor.level : 0;\n\tobject.level = options.level === undefined ? colorLevel : options.level;\n};\n\nexport class Chalk {\n\tconstructor(options) {\n\t\t// eslint-disable-next-line no-constructor-return\n\t\treturn chalkFactory(options);\n\t}\n}\n\nconst chalkFactory = options => {\n\tconst chalk = (...strings) => strings.join(' ');\n\tapplyOptions(chalk, options);\n\n\tObject.setPrototypeOf(chalk, createChalk.prototype);\n\n\treturn chalk;\n};\n\nfunction createChalk(options) {\n\treturn chalkFactory(options);\n}\n\nObject.setPrototypeOf(createChalk.prototype, Function.prototype);\n\nfor (const [styleName, style] of Object.entries(ansiStyles)) {\n\tstyles[styleName] = {\n\t\tget() {\n\t\t\tconst builder = createBuilder(this, createStyler(style.open, style.close, this[STYLER]), this[IS_EMPTY]);\n\t\t\tObject.defineProperty(this, styleName, {value: builder});\n\t\t\treturn builder;\n\t\t},\n\t};\n}\n\nstyles.visible = {\n\tget() {\n\t\tconst builder = createBuilder(this, this[STYLER], true);\n\t\tObject.defineProperty(this, 'visible', {value: builder});\n\t\treturn builder;\n\t},\n};\n\nconst getModelAnsi = (model, level, type, ...arguments_) => {\n\tif (model === 'rgb') {\n\t\tif (level === 'ansi16m') {\n\t\t\treturn ansiStyles[type].ansi16m(...arguments_);\n\t\t}\n\n\t\tif (level === 'ansi256') {\n\t\t\treturn ansiStyles[type].ansi256(ansiStyles.rgbToAnsi256(...arguments_));\n\t\t}\n\n\t\treturn ansiStyles[type].ansi(ansiStyles.rgbToAnsi(...arguments_));\n\t}\n\n\tif (model === 'hex') {\n\t\treturn getModelAnsi('rgb', level, type, ...ansiStyles.hexToRgb(...arguments_));\n\t}\n\n\treturn ansiStyles[type][model](...arguments_);\n};\n\nconst usedModels = ['rgb', 'hex', 'ansi256'];\n\nfor (const model of usedModels) {\n\tstyles[model] = {\n\t\tget() {\n\t\t\tconst {level} = this;\n\t\t\treturn function (...arguments_) {\n\t\t\t\tconst styler = createStyler(getModelAnsi(model, levelMapping[level], 'color', ...arguments_), ansiStyles.color.close, this[STYLER]);\n\t\t\t\treturn createBuilder(this, styler, this[IS_EMPTY]);\n\t\t\t};\n\t\t},\n\t};\n\n\tconst bgModel = 'bg' + model[0].toUpperCase() + model.slice(1);\n\tstyles[bgModel] = {\n\t\tget() {\n\t\t\tconst {level} = this;\n\t\t\treturn function (...arguments_) {\n\t\t\t\tconst styler = createStyler(getModelAnsi(model, levelMapping[level], 'bgColor', ...arguments_), ansiStyles.bgColor.close, this[STYLER]);\n\t\t\t\treturn createBuilder(this, styler, this[IS_EMPTY]);\n\t\t\t};\n\t\t},\n\t};\n}\n\nconst proto = Object.defineProperties(() => {}, {\n\t...styles,\n\tlevel: {\n\t\tenumerable: true,\n\t\tget() {\n\t\t\treturn this[GENERATOR].level;\n\t\t},\n\t\tset(level) {\n\t\t\tthis[GENERATOR].level = level;\n\t\t},\n\t},\n});\n\nconst createStyler = (open, close, parent) => {\n\tlet openAll;\n\tlet closeAll;\n\tif (parent === undefined) {\n\t\topenAll = open;\n\t\tcloseAll = close;\n\t} else {\n\t\topenAll = parent.openAll + open;\n\t\tcloseAll = close + parent.closeAll;\n\t}\n\n\treturn {\n\t\topen,\n\t\tclose,\n\t\topenAll,\n\t\tcloseAll,\n\t\tparent,\n\t};\n};\n\nconst createBuilder = (self, _styler, _isEmpty) => {\n\t// Single argument is hot path, implicit coercion is faster than anything\n\t// eslint-disable-next-line no-implicit-coercion\n\tconst builder = (...arguments_) => applyStyle(builder, (arguments_.length === 1) ? ('' + arguments_[0]) : arguments_.join(' '));\n\n\t// We alter the prototype because we must return a function, but there is\n\t// no way to create a function with a different prototype\n\tObject.setPrototypeOf(builder, proto);\n\n\tbuilder[GENERATOR] = self;\n\tbuilder[STYLER] = _styler;\n\tbuilder[IS_EMPTY] = _isEmpty;\n\n\treturn builder;\n};\n\nconst applyStyle = (self, string) => {\n\tif (self.level <= 0 || !string) {\n\t\treturn self[IS_EMPTY] ? '' : string;\n\t}\n\n\tlet styler = self[STYLER];\n\n\tif (styler === undefined) {\n\t\treturn string;\n\t}\n\n\tconst {openAll, closeAll} = styler;\n\tif (string.includes('\\u001B')) {\n\t\twhile (styler !== undefined) {\n\t\t\t// Replace any instances already present with a re-opening code\n\t\t\t// otherwise only the part of the string until said closing code\n\t\t\t// will be colored, and the rest will simply be 'plain'.\n\t\t\tstring = stringReplaceAll(string, styler.close, styler.open);\n\n\t\t\tstyler = styler.parent;\n\t\t}\n\t}\n\n\t// We can move both next actions out of loop, because remaining actions in loop won't have\n\t// any/visible effect on parts we add here. Close the styling before a linebreak and reopen\n\t// after next line to fix a bleed issue on macOS: https://github.com/chalk/chalk/pull/92\n\tconst lfIndex = string.indexOf('\\n');\n\tif (lfIndex !== -1) {\n\t\tstring = stringEncaseCRLFWithFirstIndex(string, closeAll, openAll, lfIndex);\n\t}\n\n\treturn openAll + string + closeAll;\n};\n\nObject.defineProperties(createChalk.prototype, styles);\n\nconst chalk = createChalk();\nexport const chalkStderr = createChalk({level: stderrColor ? stderrColor.level : 0});\n\nexport {\n\tmodifierNames,\n\tforegroundColorNames,\n\tbackgroundColorNames,\n\tcolorNames,\n\n\t// TODO: Remove these aliases in the next major version\n\tmodifierNames as modifiers,\n\tforegroundColorNames as foregroundColors,\n\tbackgroundColorNames as backgroundColors,\n\tcolorNames as colors,\n} from './vendor/ansi-styles/index.js';\n\nexport {\n\tstdoutColor as supportsColor,\n\tstderrColor as supportsColorStderr,\n};\n\nexport default chalk;\n","/*\n* loglevel - https://github.com/pimterry/loglevel\n*\n* Copyright (c) 2013 Tim Perry\n* Licensed under the MIT license.\n*/\n(function (root, definition) {\n \"use strict\";\n if (typeof define === 'function' && define.amd) {\n define(definition);\n } else if (typeof module === 'object' && module.exports) {\n module.exports = definition();\n } else {\n root.log = definition();\n }\n}(this, function () {\n \"use strict\";\n\n // Slightly dubious tricks to cut down minimized file size\n var noop = function() {};\n var undefinedType = \"undefined\";\n var isIE = (typeof window !== undefinedType) && (typeof window.navigator !== undefinedType) && (\n /Trident\\/|MSIE /.test(window.navigator.userAgent)\n );\n\n var logMethods = [\n \"trace\",\n \"debug\",\n \"info\",\n \"warn\",\n \"error\"\n ];\n\n var _loggersByName = {};\n var defaultLogger = null;\n\n // Cross-browser bind equivalent that works at least back to IE6\n function bindMethod(obj, methodName) {\n var method = obj[methodName];\n if (typeof method.bind === 'function') {\n return method.bind(obj);\n } else {\n try {\n return Function.prototype.bind.call(method, obj);\n } catch (e) {\n // Missing bind shim or IE8 + Modernizr, fallback to wrapping\n return function() {\n return Function.prototype.apply.apply(method, [obj, arguments]);\n };\n }\n }\n }\n\n // Trace() doesn't print the message in IE, so for that case we need to wrap it\n function traceForIE() {\n if (console.log) {\n if (console.log.apply) {\n console.log.apply(console, arguments);\n } else {\n // In old IE, native console methods themselves don't have apply().\n Function.prototype.apply.apply(console.log, [console, arguments]);\n }\n }\n if (console.trace) console.trace();\n }\n\n // Build the best logging method possible for this env\n // Wherever possible we want to bind, not wrap, to preserve stack traces\n function realMethod(methodName) {\n if (methodName === 'debug') {\n methodName = 'log';\n }\n\n if (typeof console === undefinedType) {\n return false; // No method possible, for now - fixed later by enableLoggingWhenConsoleArrives\n } else if (methodName === 'trace' && isIE) {\n return traceForIE;\n } else if (console[methodName] !== undefined) {\n return bindMethod(console, methodName);\n } else if (console.log !== undefined) {\n return bindMethod(console, 'log');\n } else {\n return noop;\n }\n }\n\n // These private functions always need `this` to be set properly\n\n function replaceLoggingMethods() {\n /*jshint validthis:true */\n var level = this.getLevel();\n\n // Replace the actual methods.\n for (var i = 0; i < logMethods.length; i++) {\n var methodName = logMethods[i];\n this[methodName] = (i < level) ?\n noop :\n this.methodFactory(methodName, level, this.name);\n }\n\n // Define log.log as an alias for log.debug\n this.log = this.debug;\n\n // Return any important warnings.\n if (typeof console === undefinedType && level < this.levels.SILENT) {\n return \"No console available for logging\";\n }\n }\n\n // In old IE versions, the console isn't present until you first open it.\n // We build realMethod() replacements here that regenerate logging methods\n function enableLoggingWhenConsoleArrives(methodName) {\n return function () {\n if (typeof console !== undefinedType) {\n replaceLoggingMethods.call(this);\n this[methodName].apply(this, arguments);\n }\n };\n }\n\n // By default, we use closely bound real methods wherever possible, and\n // otherwise we wait for a console to appear, and then try again.\n function defaultMethodFactory(methodName, _level, _loggerName) {\n /*jshint validthis:true */\n return realMethod(methodName) ||\n enableLoggingWhenConsoleArrives.apply(this, arguments);\n }\n\n function Logger(name, factory) {\n // Private instance variables.\n var self = this;\n /**\n * The level inherited from a parent logger (or a global default). We\n * cache this here rather than delegating to the parent so that it stays\n * in sync with the actual logging methods that we have installed (the\n * parent could change levels but we might not have rebuilt the loggers\n * in this child yet).\n * @type {number}\n */\n var inheritedLevel;\n /**\n * The default level for this logger, if any. If set, this overrides\n * `inheritedLevel`.\n * @type {number|null}\n */\n var defaultLevel;\n /**\n * A user-specific level for this logger. If set, this overrides\n * `defaultLevel`.\n * @type {number|null}\n */\n var userLevel;\n\n var storageKey = \"loglevel\";\n if (typeof name === \"string\") {\n storageKey += \":\" + name;\n } else if (typeof name === \"symbol\") {\n storageKey = undefined;\n }\n\n function persistLevelIfPossible(levelNum) {\n var levelName = (logMethods[levelNum] || 'silent').toUpperCase();\n\n if (typeof window === undefinedType || !storageKey) return;\n\n // Use localStorage if available\n try {\n window.localStorage[storageKey] = levelName;\n return;\n } catch (ignore) {}\n\n // Use session cookie as fallback\n try {\n window.document.cookie =\n encodeURIComponent(storageKey) + \"=\" + levelName + \";\";\n } catch (ignore) {}\n }\n\n function getPersistedLevel() {\n var storedLevel;\n\n if (typeof window === undefinedType || !storageKey) return;\n\n try {\n storedLevel = window.localStorage[storageKey];\n } catch (ignore) {}\n\n // Fallback to cookies if local storage gives us nothing\n if (typeof storedLevel === undefinedType) {\n try {\n var cookie = window.document.cookie;\n var cookieName = encodeURIComponent(storageKey);\n var location = cookie.indexOf(cookieName + \"=\");\n if (location !== -1) {\n storedLevel = /^([^;]+)/.exec(\n cookie.slice(location + cookieName.length + 1)\n )[1];\n }\n } catch (ignore) {}\n }\n\n // If the stored level is not valid, treat it as if nothing was stored.\n if (self.levels[storedLevel] === undefined) {\n storedLevel = undefined;\n }\n\n return storedLevel;\n }\n\n function clearPersistedLevel() {\n if (typeof window === undefinedType || !storageKey) return;\n\n // Use localStorage if available\n try {\n window.localStorage.removeItem(storageKey);\n } catch (ignore) {}\n\n // Use session cookie as fallback\n try {\n window.document.cookie =\n encodeURIComponent(storageKey) + \"=; expires=Thu, 01 Jan 1970 00:00:00 UTC\";\n } catch (ignore) {}\n }\n\n function normalizeLevel(input) {\n var level = input;\n if (typeof level === \"string\" && self.levels[level.toUpperCase()] !== undefined) {\n level = self.levels[level.toUpperCase()];\n }\n if (typeof level === \"number\" && level >= 0 && level <= self.levels.SILENT) {\n return level;\n } else {\n throw new TypeError(\"log.setLevel() called with invalid level: \" + input);\n }\n }\n\n /*\n *\n * Public logger API - see https://github.com/pimterry/loglevel for details\n *\n */\n\n self.name = name;\n\n self.levels = { \"TRACE\": 0, \"DEBUG\": 1, \"INFO\": 2, \"WARN\": 3,\n \"ERROR\": 4, \"SILENT\": 5};\n\n self.methodFactory = factory || defaultMethodFactory;\n\n self.getLevel = function () {\n if (userLevel != null) {\n return userLevel;\n } else if (defaultLevel != null) {\n return defaultLevel;\n } else {\n return inheritedLevel;\n }\n };\n\n self.setLevel = function (level, persist) {\n userLevel = normalizeLevel(level);\n if (persist !== false) { // defaults to true\n persistLevelIfPossible(userLevel);\n }\n\n // NOTE: in v2, this should call rebuild(), which updates children.\n return replaceLoggingMethods.call(self);\n };\n\n self.setDefaultLevel = function (level) {\n defaultLevel = normalizeLevel(level);\n if (!getPersistedLevel()) {\n self.setLevel(level, false);\n }\n };\n\n self.resetLevel = function () {\n userLevel = null;\n clearPersistedLevel();\n replaceLoggingMethods.call(self);\n };\n\n self.enableAll = function(persist) {\n self.setLevel(self.levels.TRACE, persist);\n };\n\n self.disableAll = function(persist) {\n self.setLevel(self.levels.SILENT, persist);\n };\n\n self.rebuild = function () {\n if (defaultLogger !== self) {\n inheritedLevel = normalizeLevel(defaultLogger.getLevel());\n }\n replaceLoggingMethods.call(self);\n\n if (defaultLogger === self) {\n for (var childName in _loggersByName) {\n _loggersByName[childName].rebuild();\n }\n }\n };\n\n // Initialize all the internal levels.\n inheritedLevel = normalizeLevel(\n defaultLogger ? defaultLogger.getLevel() : \"WARN\"\n );\n var initialLevel = getPersistedLevel();\n if (initialLevel != null) {\n userLevel = normalizeLevel(initialLevel);\n }\n replaceLoggingMethods.call(self);\n }\n\n /*\n *\n * Top-level API\n *\n */\n\n defaultLogger = new Logger();\n\n defaultLogger.getLogger = function getLogger(name) {\n if ((typeof name !== \"symbol\" && typeof name !== \"string\") || name === \"\") {\n throw new TypeError(\"You must supply a name when creating a logger.\");\n }\n\n var logger = _loggersByName[name];\n if (!logger) {\n logger = _loggersByName[name] = new Logger(\n name,\n defaultLogger.methodFactory\n );\n }\n return logger;\n };\n\n // Grab the current global log variable in case of overwrite\n var _log = (typeof window !== undefinedType) ? window.log : undefined;\n defaultLogger.noConflict = function() {\n if (typeof window !== undefinedType &&\n window.log === defaultLogger) {\n window.log = _log;\n }\n\n return defaultLogger;\n };\n\n defaultLogger.getLoggers = function getLoggers() {\n return _loggersByName;\n };\n\n // ES6 default export, for compatibility\n defaultLogger['default'] = defaultLogger;\n\n return defaultLogger;\n}));\n","(function (root, factory) {\n if (typeof define === 'function' && define.amd) {\n define(factory);\n } else if (typeof module === 'object' && module.exports) {\n module.exports = factory();\n } else {\n root.prefix = factory(root);\n }\n}(this, function (root) {\n 'use strict';\n\n var merge = function (target) {\n var i = 1;\n var length = arguments.length;\n var key;\n for (; i < length; i++) {\n for (key in arguments[i]) {\n if (Object.prototype.hasOwnProperty.call(arguments[i], key)) {\n target[key] = arguments[i][key];\n }\n }\n }\n return target;\n };\n\n var defaults = {\n template: '[%t] %l:',\n levelFormatter: function (level) {\n return level.toUpperCase();\n },\n nameFormatter: function (name) {\n return name || 'root';\n },\n timestampFormatter: function (date) {\n return date.toTimeString().replace(/.*(\\d{2}:\\d{2}:\\d{2}).*/, '$1');\n },\n format: undefined\n };\n\n var loglevel;\n var configs = {};\n\n var reg = function (rootLogger) {\n if (!rootLogger || !rootLogger.getLogger) {\n throw new TypeError('Argument is not a root logger');\n }\n loglevel = rootLogger;\n };\n\n var apply = function (logger, config) {\n if (!logger || !logger.setLevel) {\n throw new TypeError('Argument is not a logger');\n }\n\n /* eslint-disable vars-on-top */\n var originalFactory = logger.methodFactory;\n var name = logger.name || '';\n var parent = configs[name] || configs[''] || defaults;\n /* eslint-enable vars-on-top */\n\n function methodFactory(methodName, logLevel, loggerName) {\n var originalMethod = originalFactory(methodName, logLevel, loggerName);\n var options = configs[loggerName] || configs[''];\n\n var hasTimestamp = options.template.indexOf('%t') !== -1;\n var hasLevel = options.template.indexOf('%l') !== -1;\n var hasName = options.template.indexOf('%n') !== -1;\n\n return function () {\n var content = '';\n\n var length = arguments.length;\n var args = Array(length);\n var key = 0;\n for (; key < length; key++) {\n args[key] = arguments[key];\n }\n\n // skip the root method for child loggers to prevent duplicate logic\n if (name || !configs[loggerName]) {\n /* eslint-disable vars-on-top */\n var timestamp = options.timestampFormatter(new Date());\n var level = options.levelFormatter(methodName);\n var lname = options.nameFormatter(loggerName);\n /* eslint-enable vars-on-top */\n\n if (options.format) {\n content += options.format(level, lname, timestamp);\n } else {\n content += options.template;\n if (hasTimestamp) {\n content = content.replace(/%t/, timestamp);\n }\n if (hasLevel) content = content.replace(/%l/, level);\n if (hasName) content = content.replace(/%n/, lname);\n }\n\n if (args.length && typeof args[0] === 'string') {\n // concat prefix with first argument to support string substitutions\n args[0] = content + ' ' + args[0];\n } else {\n args.unshift(content);\n }\n }\n\n originalMethod.apply(undefined, args);\n };\n }\n\n if (!configs[name]) {\n logger.methodFactory = methodFactory;\n }\n\n // for remove inherited format option if template option preset\n config = config || {};\n if (config.template) config.format = undefined;\n\n configs[name] = merge({}, parent, config);\n\n logger.setLevel(logger.getLevel());\n\n if (!loglevel) {\n logger.warn(\n 'It is necessary to call the function reg() of loglevel-plugin-prefix before calling apply. From the next release, it will throw an error. See more: https://github.com/kutuluk/loglevel-plugin-prefix/blob/master/README.md'\n );\n }\n\n return logger;\n };\n\n var api = {\n reg: reg,\n apply: apply\n };\n\n var save;\n\n if (root) {\n save = root.prefix;\n api.noConflict = function () {\n if (root.prefix === api) {\n root.prefix = save;\n }\n return api;\n };\n }\n\n return api;\n}));\n","import { configureSync, getConsoleSink, getLogger } from \"@logtape/logtape\";\nimport chalk from \"chalk\";\nimport log, { type Logger } from \"loglevel\";\nimport prefix from \"loglevel-plugin-prefix\";\n\n// Récupère les variables d'environnement au sein d'un objet.\nconst environment = import.meta.env;\n\nconst colors = {\n DEBUG: chalk.cyan,\n ERROR: chalk.red,\n INFO: chalk.blue,\n TRACE: chalk.magenta,\n WARN: chalk.yellow,\n};\n\nexport const logger: Logger = log.noConflict() as Logger;\nlogger.enableAll(true);\nlogger.setDefaultLevel(\"DEBUG\");\nprefix.reg(logger);\nprefix.apply(logger, {\n format(level, _, timestamp) {\n return `${chalk.gray(`[${timestamp}]`)} ${colors[level.toUpperCase()](level)}`;\n },\n});\n\nconst HAIKU_ATELIER_LOGGER = \"haiku-atelier\";\nconfigureSync({\n loggers: [\n {\n category: HAIKU_ATELIER_LOGGER,\n lowestLevel: environment.VITE_MODE === \"production\" ? \"warning\" : \"debug\",\n sinks: [\"console\"],\n },\n ],\n sinks: { console: getConsoleSink() },\n});\n\nexport const nuLogger = getLogger(HAIKU_ATELIER_LOGGER);\n"],"x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/journalisation.js b/web/app/themes/haiku-atelier-2024/assets/js/journalisation.js new file mode 100644 index 00000000..f94d2a02 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/journalisation.js @@ -0,0 +1,3 @@ +import { n as nuLogger, t as logger } from "./journalisation.CEgm28xa.js"; + +export { logger, nuLogger }; \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js b/web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js new file mode 100644 index 00000000..c407f90c --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js @@ -0,0 +1,253 @@ +import { dt as pipe } from "./exports.CurVqjr0.js"; +import { A as integer, B as parse, D as boolean, E as array, F as null_, G as unknown, H as string, I as number, K as url, L as object, O as enum_, R as omit, S as reporteErreur, U as transform, V as pipe$1, W as union, X as Either, q as value } from "./dom.emspS_OW.js"; +import { r as WCErrorSchema, t as safeSchemaParse } from "./validation.CYJDC5vQ.js"; + +//#region web/app/themes/haiku-atelier-2024/src/scripts/constantes/messages.ts +/** Constantes liées aux Messages passés par BroadcastChannel. */ +const NOM_CANAL_BOUTON_PANIER = "bouton_panier"; +const NOM_CANAL_CONTENU_PANIER = "contenu_panier"; +const NOM_CANAL_REVALIDATION_LIVRAISON = "revalidation_livraison"; +const TYPES_MESSAGES = { + MajBoutonPanier: "maj_bouton_panier", + MajContenuPanier: "maj_contenu_panier", + RevalidationLivraison: "revalidation_livraison" +}; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/constantes/api/cart.ts +/** Constantes liées aux Paniers WooCommerce. */ +const CATALOG_VISIBILITIES = { + INVISIBLE: "invisible", + VISIBLE: "visible" +}; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/schemas/api/adresses.ts +const WCStoreBillingAddressSchema = object({ + address_1: string(), + address_2: string(), + city: string(), + company: string(), + country: string(), + email: string(), + first_name: string(), + last_name: string(), + phone: string(), + postcode: string(), + state: string() +}); +const WCStoreShippingAddressSchema = object({ + address_1: string(), + address_2: string(), + city: string(), + company: string(), + country: string(), + first_name: string(), + last_name: string(), + phone: string(), + postcode: string(), + state: string() +}); + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/schemas/api/cart-coupons.ts +const WCStoreCartCouponsArgSchema = object({ code: string() }); +const WCStoreCartCouponsSchema = object({ + code: string(), + discount_type: string(), + totals: object({ + currency_code: string(), + currency_decimal_separator: string(), + currency_minor_unit: pipe$1(number(), integer()), + currency_prefix: string(), + currency_suffix: string(), + currency_symbol: string(), + currency_thousand_separator: string(), + total_discount: string(), + total_discount_tax: string() + }) +}); + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/schemas/api/couts-livraison.ts +const WCStoreShippingRateItemSchema = object({ + key: string(), + name: string(), + quantity: number() +}); +const WCStoreShippingRateShippingRateSchema = object({ + currency_code: string(), + currency_decimal_separator: string(), + currency_minor_unit: number(), + currency_prefix: string(), + currency_suffix: string(), + currency_symbol: string(), + currency_thousand_separator: string(), + delivery_time: string(), + description: string(), + instance_id: number(), + meta_data: array(unknown()), + method_id: string(), + name: string(), + price: pipe$1(union([string(), number()]), transform(Number)), + rate_id: string(), + selected: boolean(), + taxes: string() +}); +const WCStoreShippingRateShippingRatesSchema = array(WCStoreShippingRateShippingRateSchema); +const WCStoreShippingRateSchema = object({ + destination: omit(WCStoreShippingAddressSchema, [ + "company", + "first_name", + "last_name", + "phone" + ]), + items: array(WCStoreShippingRateItemSchema), + name: string(), + package_id: number(), + shipping_rates: WCStoreShippingRateShippingRatesSchema +}); + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/schemas/api/cart.ts +const WCStoreCartItemTotalsSchema = object({ + currency_code: string(), + currency_decimal_separator: string(), + currency_minor_unit: number(), + currency_prefix: string(), + currency_suffix: string(), + currency_symbol: string(), + currency_thousand_separator: string(), + line_subtotal: string(), + line_subtotal_tax: string(), + line_total: string(), + line_total_tax: string() +}); +const WCStoreCartItemSchema = object({ + backorders_allowed: boolean(), + catalog_visibility: enum_(CATALOG_VISIBILITIES), + description: string(), + extensions: unknown(), + id: number(), + images: array(unknown()), + item_data: array(unknown()), + key: string(), + low_stock_remaining: union([null_()]), + name: string(), + permalink: pipe$1(string(), url()), + prices: unknown(), + quantity: number(), + quantity_limits: unknown(), + short_description: string(), + show_backorder_badge: boolean(), + sku: string(), + sold_individually: boolean(), + totals: WCStoreCartItemTotalsSchema, + type: string(), + variation: array(unknown()) +}); +const WCStoreCartTotalsSchema = object({ + currency_code: string(), + currency_decimal_separator: string(), + currency_minor_unit: number(), + currency_prefix: string(), + currency_suffix: string(), + currency_symbol: string(), + currency_thousand_separator: string(), + tax_lines: array(unknown()), + total_discount: pipe$1(union([string(), number()]), transform(Number)), + total_discount_tax: string(), + total_fees: string(), + total_fees_tax: string(), + total_items: pipe$1(union([string(), number()]), transform(Number)), + total_items_tax: string(), + total_price: pipe$1(union([string(), number()]), transform(Number)), + total_shipping: pipe$1(union([ + string(), + number(), + null_() + ]), transform((n) => n ? Number(n) : 0)), + total_shipping_tax: union([string(), null_()]), + total_tax: string() +}); +const WCStoreCartSchema = object({ + billing_address: WCStoreBillingAddressSchema, + coupons: array(WCStoreCartCouponsSchema), + cross_sells: unknown(), + errors: unknown(), + extensions: unknown(), + fees: unknown(), + has_calculated_shipping: boolean(), + items: array(WCStoreCartItemSchema), + items_count: pipe$1(number(), integer()), + items_weight: pipe$1(number(), integer()), + needs_payment: boolean(), + needs_shipping: boolean(), + payment_methods: unknown(), + payment_requirements: unknown(), + shipping_address: WCStoreShippingAddressSchema, + shipping_rates: array(WCStoreShippingRateSchema), + totals: WCStoreCartTotalsSchema +}); + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/schemas/messages.ts +const TypesMessagesSchema = enum_(TYPES_MESSAGES); +const MessageMajBoutonPanierDonneesSchema = object({ quantiteProduits: number() }); +const MessageMajBoutonPanierSchema = object({ + donnees: MessageMajBoutonPanierDonneesSchema, + type: pipe$1(string(), value(TYPES_MESSAGES.MajBoutonPanier)) +}); +const MessageMajContenuPanierDonneesSchema = object({ + produits: array(WCStoreCartItemSchema), + sousTotalProduits: number(), + sousTotalReduction: number(), + totalPanier: number() +}); +const MessageMajContenuPanierSchema = object({ + donnees: MessageMajContenuPanierDonneesSchema, + type: pipe$1(string(), value(TYPES_MESSAGES.MajContenuPanier)) +}); + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/messages.ts +var canalPostMessage = (canal, message) => { + canal.postMessage(message); + return canal; +}; +const emetMessageMajBoutonPanier = (args) => { + const canal = new BroadcastChannel(NOM_CANAL_BOUTON_PANIER); + canal.postMessage({ + donnees: { quantiteProduits: args.quantiteProduits }, + type: TYPES_MESSAGES.MajBoutonPanier + }); + canal.close(); +}; +const emetMessageMajContenuPanier = (args) => { + const canal = new BroadcastChannel(NOM_CANAL_CONTENU_PANIER); + canal.postMessage({ + donnees: { + produits: args.produits, + sousTotalProduits: args.sousTotalProduits, + sousTotalReduction: args.sousTotalReduction, + totalPanier: args.totalPanier + }, + type: TYPES_MESSAGES.MajContenuPanier + }); + canal.close(); +}; +/** +* Émet un unique message vers un BroadcastChannel (canal) généré sur le moment puis le ferme. +* +* @param nomCanal Le nom du BroadcastChannel pour lequel le message est émis. +* @param message Le message émis. +* @return void +*/ +const emetUniqueMessageBroadcastChannel = (nomCanal, message) => pipe(new BroadcastChannel(nomCanal), (canal) => canalPostMessage(canal, message), (canal) => canal.close()); +const valideMessageMajBoutonPanier = (evenementMessage) => Either.of(parse(MessageMajBoutonPanierSchema, evenementMessage.data)).ifLeft((erreur) => reporteErreur(erreur)); +const valideMessageMajContenuPanier = (evenementMessage) => Either.of(parse(MessageMajContenuPanierSchema, evenementMessage.data)).ifLeft((erreur) => reporteErreur(erreur)); +const reponseEstCodeErreurWC = (reponse, codeErreurWC) => safeSchemaParse(reponse, WCErrorSchema).map((v) => v.body.code === codeErreurWC).orDefault(false); + +//#endregion +export { valideMessageMajBoutonPanier as a, WCStoreCartTotalsSchema as c, WCStoreShippingAddressSchema as d, NOM_CANAL_BOUTON_PANIER as f, reponseEstCodeErreurWC as i, WCStoreShippingRateShippingRatesSchema as l, NOM_CANAL_REVALIDATION_LIVRAISON as m, emetMessageMajContenuPanier as n, valideMessageMajContenuPanier as o, NOM_CANAL_CONTENU_PANIER as p, emetUniqueMessageBroadcastChannel as r, WCStoreCartSchema as s, emetMessageMajBoutonPanier as t, WCStoreBillingAddressSchema as u }; +//# sourceMappingURL=messages.CqHLtCes.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js.map b/web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js.map new file mode 100644 index 00000000..46d91909 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/messages.CqHLtCes.js.map @@ -0,0 +1 @@ +{"version":3,"file":"messages.CqHLtCes.js","names":[],"sources":["../../src/scripts/constantes/messages.ts","../../src/scripts/constantes/api/cart.ts","../../src/scripts/lib/schemas/api/adresses.ts","../../src/scripts/lib/schemas/api/cart-coupons.ts","../../src/scripts/lib/schemas/api/couts-livraison.ts","../../src/scripts/lib/schemas/api/cart.ts","../../src/scripts/lib/schemas/messages.ts","../../src/scripts/lib/messages.ts"],"sourcesContent":["/** Constantes liées aux Messages passés par BroadcastChannel. */\n\nexport const NOM_CANAL_BOUTON_PANIER = \"bouton_panier\";\nexport const NOM_CANAL_CONTENU_PANIER = \"contenu_panier\";\nexport const NOM_CANAL_REVALIDATION_LIVRAISON = \"revalidation_livraison\";\n\nexport const TYPES_MESSAGES = {\n MajBoutonPanier: \"maj_bouton_panier\",\n MajContenuPanier: \"maj_contenu_panier\",\n RevalidationLivraison: \"revalidation_livraison\",\n} as const;\n","/** Constantes liées aux Paniers WooCommerce. */\n\nexport const CATALOG_VISIBILITIES = {\n INVISIBLE: \"invisible\",\n VISIBLE: \"visible\",\n} as const;\n","import * as v from \"valibot\";\n\nexport const WCStoreBillingAddressSchema = v.object({\n address_1: v.string(),\n address_2: v.string(),\n city: v.string(),\n company: v.string(),\n country: v.string(),\n // email: v.optional(v.pipe(v.string(), v.email())),\n email: v.string(),\n first_name: v.string(),\n last_name: v.string(),\n phone: v.string(),\n postcode: v.string(),\n state: v.string(),\n});\n\nexport const WCStoreShippingAddressSchema = v.object({\n address_1: v.string(),\n address_2: v.string(),\n city: v.string(),\n company: v.string(),\n country: v.string(),\n first_name: v.string(),\n last_name: v.string(),\n phone: v.string(),\n postcode: v.string(),\n state: v.string(),\n});\n","import * as v from \"valibot\";\n\nexport const WCStoreCartCouponsArgSchema = v.object({\n // Unique identifier for the coupon within the basket.\n code: v.string(),\n});\n\nexport const WCStoreCartCouponsSchema = v.object({\n /** The coupon's unique code. */\n code: v.string(),\n // The discount type for the coupon (eg percentage or fixed amount)\n discount_type: v.string(),\n // Total amounts provided using the smallest unit of the currency.\n totals: v.object({\n // Currency code (in ISO format) for returned prices.\n currency_code: v.string(),\n // Decimal separator for the currency which can be used to format returned prices.\n currency_decimal_separator: v.string(),\n // Currency minor unit (number of digits after the decimal separator) for returned prices.\n currency_minor_unit: v.pipe(v.number(), v.integer()),\n // Price prefix for the currency which can be used to format returned prices.\n currency_prefix: v.string(),\n // Price prefix for the currency which can be used to format returned prices.\n currency_suffix: v.string(),\n // Currency symbol for the currency which can be used to format returned prices.\n currency_symbol: v.string(),\n // Thousand separator for the currency which can be used to format returned prices.\n currency_thousand_separator: v.string(),\n // Total discount applied by this coupon.\n total_discount: v.string(),\n // Total tax removed due to discount applied by this coupon.\n total_discount_tax: v.string(),\n }),\n});\n","// Coûts de livraison (\"shipping rates\")\n\nimport * as v from \"valibot\";\n\nimport { WCStoreShippingAddressSchema } from \"./adresses.ts\";\n\nexport const WCStoreShippingRateItemSchema = v.object({\n key: v.string(),\n name: v.string(),\n quantity: v.number(),\n});\n\nexport const WCStoreShippingRateShippingRateSchema = v.object({\n currency_code: v.string(),\n currency_decimal_separator: v.string(),\n currency_minor_unit: v.number(),\n currency_prefix: v.string(),\n currency_suffix: v.string(),\n currency_symbol: v.string(),\n currency_thousand_separator: v.string(),\n delivery_time: v.string(),\n description: v.string(),\n instance_id: v.number(),\n meta_data: v.array(v.unknown()),\n method_id: v.string(),\n name: v.string(),\n price: v.pipe(\n v.union([v.string(), v.number()]),\n v.transform(Number),\n ),\n rate_id: v.string(),\n selected: v.boolean(),\n taxes: v.string(),\n});\n\nexport const WCStoreShippingRateShippingRatesSchema = v.array(WCStoreShippingRateShippingRateSchema);\n\nexport const WCStoreShippingRateSchema = v.object({\n destination: v.omit(WCStoreShippingAddressSchema, [\"company\", \"first_name\", \"last_name\", \"phone\"]),\n items: v.array(WCStoreShippingRateItemSchema),\n name: v.string(),\n package_id: v.number(),\n shipping_rates: WCStoreShippingRateShippingRatesSchema,\n});\n","import * as v from \"valibot\";\n\nimport { CATALOG_VISIBILITIES } from \"../../../constantes/api/cart.ts\";\nimport { WCStoreBillingAddressSchema, WCStoreShippingAddressSchema } from \"./adresses.ts\";\nimport { WCStoreCartCouponsSchema } from \"./cart-coupons.ts\";\nimport { WCStoreShippingRateSchema } from \"./couts-livraison.ts\";\n\nexport const WCStoreCartItemTotalsSchema = v.object({\n currency_code: v.string(),\n currency_decimal_separator: v.string(),\n currency_minor_unit: v.number(),\n currency_prefix: v.string(),\n currency_suffix: v.string(),\n currency_symbol: v.string(),\n currency_thousand_separator: v.string(),\n line_subtotal: v.string(),\n line_subtotal_tax: v.string(),\n line_total: v.string(),\n line_total_tax: v.string(),\n});\n\nexport const WCStoreCartItemSchema = v.object({\n backorders_allowed: v.boolean(),\n catalog_visibility: v.enum(CATALOG_VISIBILITIES),\n description: v.string(),\n extensions: v.unknown(),\n id: v.number(),\n images: v.array(v.unknown()),\n item_data: v.array(v.unknown()),\n key: v.string(),\n low_stock_remaining: v.union([v.null()]),\n name: v.string(),\n permalink: v.pipe(v.string(), v.url()),\n prices: v.unknown(),\n quantity: v.number(),\n quantity_limits: v.unknown(),\n short_description: v.string(),\n show_backorder_badge: v.boolean(),\n sku: v.string(),\n sold_individually: v.boolean(),\n totals: WCStoreCartItemTotalsSchema,\n type: v.string(),\n variation: v.array(v.unknown()),\n});\n\nexport const WCStoreCartTotalsSchema = v.object({\n currency_code: v.string(),\n currency_decimal_separator: v.string(),\n currency_minor_unit: v.number(),\n currency_prefix: v.string(),\n currency_suffix: v.string(),\n currency_symbol: v.string(),\n currency_thousand_separator: v.string(),\n tax_lines: v.array(v.unknown()),\n total_discount: v.pipe(\n v.union([v.string(), v.number()]),\n v.transform(Number),\n ),\n total_discount_tax: v.string(),\n total_fees: v.string(),\n total_fees_tax: v.string(),\n total_items: v.pipe(\n v.union([v.string(), v.number()]),\n v.transform(Number),\n ),\n total_items_tax: v.string(),\n total_price: v.pipe(\n v.union([v.string(), v.number()]),\n v.transform(Number),\n ),\n total_shipping: v.pipe(\n v.union([v.string(), v.number(), v.null()]),\n v.transform(n => n ? Number(n) : 0),\n ),\n total_shipping_tax: v.union([v.string(), v.null()]),\n total_tax: v.string(),\n});\n\nexport const WCStoreCartSchema = v.object({\n billing_address: WCStoreBillingAddressSchema,\n /** List of applied basket coupons. */\n coupons: v.array(WCStoreCartCouponsSchema),\n cross_sells: v.unknown(),\n errors: v.unknown(),\n extensions: v.unknown(),\n fees: v.unknown(),\n has_calculated_shipping: v.boolean(),\n items: v.array(WCStoreCartItemSchema),\n items_count: v.pipe(v.number(), v.integer()),\n items_weight: v.pipe(v.number(), v.integer()),\n needs_payment: v.boolean(),\n needs_shipping: v.boolean(),\n payment_methods: v.unknown(),\n payment_requirements: v.unknown(),\n shipping_address: WCStoreShippingAddressSchema,\n shipping_rates: v.array(WCStoreShippingRateSchema),\n totals: WCStoreCartTotalsSchema,\n});\n","/** Schémas des Messages passés avec BroadcastChannel. */\n\nimport * as v from \"valibot\";\n\nimport { TYPES_MESSAGES } from \"../../constantes/messages.ts\";\nimport { WCStoreCartItemSchema } from \"./api/cart.ts\";\n\nexport const TypesMessagesSchema = v.enum(TYPES_MESSAGES);\n\nexport const MessageMajBoutonPanierDonneesSchema = v.object({\n quantiteProduits: v.number(),\n});\n\nexport const MessageMajBoutonPanierSchema = v.object({\n donnees: MessageMajBoutonPanierDonneesSchema,\n type: v.pipe(v.string(), v.value(TYPES_MESSAGES.MajBoutonPanier)),\n});\n\nexport const MessageMajContenuPanierDonneesSchema = v.object({\n produits: v.array(WCStoreCartItemSchema),\n sousTotalProduits: v.number(),\n sousTotalReduction: v.number(),\n totalPanier: v.number(),\n});\n\nexport const MessageMajContenuPanierSchema = v.object({\n donnees: MessageMajContenuPanierDonneesSchema,\n type: v.pipe(v.string(), v.value(TYPES_MESSAGES.MajContenuPanier)),\n});\n","import { pipe } from \"@mobily/ts-belt\";\nimport { Either } from \"purify-ts\";\nimport { parse, type ValiError } from \"valibot\";\n\nimport type {\n MessageMajBoutonPanier,\n MessageMajBoutonPanierDonnees,\n MessageMajContenuPanier,\n MessageMajContenuPanierDonnees,\n} from \"./types/messages\";\nimport type { SimplifiedResponse } from \"./types/reseau\";\n\nimport { NOM_CANAL_BOUTON_PANIER, NOM_CANAL_CONTENU_PANIER, TYPES_MESSAGES } from \"../constantes/messages.ts\";\nimport { reporteErreur } from \"./erreurs.ts\";\nimport { WCErrorSchema } from \"./schemas/api/erreurs.ts\";\nimport { MessageMajBoutonPanierSchema, MessageMajContenuPanierSchema } from \"./schemas/messages.ts\";\nimport { safeSchemaParse } from \"./validation.ts\";\n\nconst canalPostMessage = (canal: BroadcastChannel, message: unknown): BroadcastChannel => {\n canal.postMessage(message);\n return canal;\n};\n\n// Émissions\nexport const emetMessageMajBoutonPanier = (args: MessageMajBoutonPanierDonnees): void => {\n const canal = new BroadcastChannel(NOM_CANAL_BOUTON_PANIER);\n canal.postMessage({\n donnees: {\n quantiteProduits: args.quantiteProduits,\n },\n type: TYPES_MESSAGES.MajBoutonPanier,\n } as MessageMajBoutonPanier);\n canal.close();\n};\n\nexport const emetMessageMajContenuPanier = (args: MessageMajContenuPanierDonnees): void => {\n const canal = new BroadcastChannel(NOM_CANAL_CONTENU_PANIER);\n canal.postMessage({\n donnees: {\n produits: args.produits,\n sousTotalProduits: args.sousTotalProduits,\n sousTotalReduction: args.sousTotalReduction,\n totalPanier: args.totalPanier,\n },\n type: TYPES_MESSAGES.MajContenuPanier,\n } as MessageMajContenuPanier);\n canal.close();\n};\n\n/**\n * Émet un unique message vers un BroadcastChannel (canal) généré sur le moment puis le ferme.\n *\n * @param nomCanal Le nom du BroadcastChannel pour lequel le message est émis.\n * @param message Le message émis.\n * @return void\n */\nexport const emetUniqueMessageBroadcastChannel = (nomCanal: string, message: M): void =>\n pipe(new BroadcastChannel(nomCanal), canal => canalPostMessage(canal, message), canal => canal.close());\n\n// Validations\nexport const valideMessageMajBoutonPanier = (\n evenementMessage: MessageEvent,\n): Either, MessageMajBoutonPanier> =>\n Either\n .of, MessageMajBoutonPanier>(\n parse(MessageMajBoutonPanierSchema, evenementMessage.data),\n )\n .ifLeft(erreur => reporteErreur(erreur));\n\nexport const valideMessageMajContenuPanier = (\n evenementMessage: MessageEvent,\n): Either, MessageMajContenuPanier> =>\n Either\n .of, MessageMajContenuPanier>(\n parse(MessageMajContenuPanierSchema, evenementMessage.data),\n )\n .ifLeft(erreur => reporteErreur(erreur));\n\n// Correspondances\nexport const reponseEstCodeErreurWC = (reponse: SimplifiedResponse, codeErreurWC: string): boolean =>\n safeSchemaParse(reponse, WCErrorSchema)\n .map(v => v.body.code === codeErreurWC)\n .orDefault(false);\n"],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js b/web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js new file mode 100644 index 00000000..7597a3e1 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js @@ -0,0 +1,176 @@ +import { dt as pipe } from "./exports.CurVqjr0.js"; + +//#region node_modules/@mobily/ts-belt/dist/index-272b4672.mjs +function mod_(t$1, n$1) { + if (0 === n$1) throw { + RE_EXN_ID: "Division_by_zero", + Error: /* @__PURE__ */ new Error() + }; + return t$1 % n$1; +} +function placeholder(t$1) {} +function pred(t$1) { + return t$1 - 1 | 0; +} +function succ(t$1) { + return t$1 + 1 | 0; +} +function _add(t$1, n$1) { + return t$1 + n$1; +} +function add() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _add(n$1, t$1[0]); + }; + } + return _add(arguments[0], arguments[1]); +} +function _subtract(t$1, n$1) { + return t$1 - n$1; +} +function subtract() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _subtract(n$1, t$1[0]); + }; + } + return _subtract(arguments[0], arguments[1]); +} +function _multiply(t$1, n$1) { + return t$1 * n$1; +} +function multiply() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _multiply(n$1, t$1[0]); + }; + } + return _multiply(arguments[0], arguments[1]); +} +function _divide(t$1, n$1) { + return t$1 / n$1; +} +function divide() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _divide(n$1, t$1[0]); + }; + } + return _divide(arguments[0], arguments[1]); +} +var t = mod_; +function modulo() { + if (1 === arguments.length) { + const n$1 = arguments; + return function fn(r) { + return t(r, n$1[0]); + }; + } + return t(arguments[0], arguments[1]); +} +function _divideWithModulo(t$1, n$1) { + return [t$1 / n$1, mod_(0 | t$1, 0 | n$1)]; +} +function divideWithModulo() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _divideWithModulo(n$1, t$1[0]); + }; + } + return _divideWithModulo(arguments[0], arguments[1]); +} +function _gt(t$1, n$1) { + return t$1 > n$1; +} +function gt() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _gt(n$1, t$1[0]); + }; + } + return _gt(arguments[0], arguments[1]); +} +function _gte(t$1, n$1) { + return t$1 >= n$1; +} +function gte() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _gte(n$1, t$1[0]); + }; + } + return _gte(arguments[0], arguments[1]); +} +function _lt(t$1, n$1) { + return t$1 < n$1; +} +function lt() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _lt(n$1, t$1[0]); + }; + } + return _lt(arguments[0], arguments[1]); +} +function _lte(t$1, n$1) { + return t$1 <= n$1; +} +function lte() { + if (1 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _lte(n$1, t$1[0]); + }; + } + return _lte(arguments[0], arguments[1]); +} +function _clamp(t$1, n$1, r) { + return Math.min(Math.max(t$1, n$1), r); +} +function clamp() { + if (2 === arguments.length) { + const t$1 = arguments; + return function fn(n$1) { + return _clamp(n$1, t$1[0], t$1[1]); + }; + } + return _clamp(arguments[0], arguments[1], arguments[2]); +} +var n = { + __proto__: null, + placeholder, + pred, + succ, + add, + subtract, + multiply, + divide, + modulo, + divideWithModulo, + gt, + gte, + lt, + lte, + clamp +}; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/nombres.ts +const estEntreDeuxNombres = (nombre, min, max) => n.gte(nombre, min) && n.lt(nombre, max); +const diviseParCent = (nombre) => Number(nombre) / 100; +const arrondisADeuxDecimales = (nombre) => pipe(Number(nombre), (n$1) => n$1.toFixed(2)); +const inverseNombre = (nombre) => Number(nombre) * -1; +const formateEnEuros = (nombre) => `${String(nombre)}€`; + +//#endregion +export { inverseNombre as a, formateEnEuros as i, diviseParCent as n, estEntreDeuxNombres as r, arrondisADeuxDecimales as t }; +//# sourceMappingURL=nombres.E65h3XxA.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js.map b/web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js.map new file mode 100644 index 00000000..105e9537 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/nombres.E65h3XxA.js.map @@ -0,0 +1 @@ +{"version":3,"file":"nombres.E65h3XxA.js","names":["n","t"],"sources":["../../../../../../node_modules/@mobily/ts-belt/dist/index-272b4672.mjs","../../src/scripts/lib/nombres.ts"],"sourcesContent":["function mod_(t, n) {\n if (0 === n) {\n throw {\n RE_EXN_ID: \"Division_by_zero\",\n Error: new Error\n };\n }\n return t % n;\n}\n\nfunction placeholder(t) {}\n\nfunction pred(t) {\n return t - 1 | 0;\n}\n\nfunction succ(t) {\n return t + 1 | 0;\n}\n\nfunction _add(t, n) {\n return t + n;\n}\n\nfunction add() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _add(n, t[0]);\n };\n }\n return _add(arguments[0], arguments[1]);\n}\n\nfunction _subtract(t, n) {\n return t - n;\n}\n\nfunction subtract() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _subtract(n, t[0]);\n };\n }\n return _subtract(arguments[0], arguments[1]);\n}\n\nfunction _multiply(t, n) {\n return t * n;\n}\n\nfunction multiply() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _multiply(n, t[0]);\n };\n }\n return _multiply(arguments[0], arguments[1]);\n}\n\nfunction _divide(t, n) {\n return t / n;\n}\n\nfunction divide() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _divide(n, t[0]);\n };\n }\n return _divide(arguments[0], arguments[1]);\n}\n\nvar t = mod_;\n\nfunction modulo() {\n if (1 === arguments.length) {\n const n = arguments;\n return function fn(r) {\n return t(r, n[0]);\n };\n }\n return t(arguments[0], arguments[1]);\n}\n\nfunction _divideWithModulo(t, n) {\n return [ t / n, mod_(0 | t, 0 | n) ];\n}\n\nfunction divideWithModulo() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _divideWithModulo(n, t[0]);\n };\n }\n return _divideWithModulo(arguments[0], arguments[1]);\n}\n\nfunction _gt(t, n) {\n return t > n;\n}\n\nfunction gt() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _gt(n, t[0]);\n };\n }\n return _gt(arguments[0], arguments[1]);\n}\n\nfunction _gte(t, n) {\n return t >= n;\n}\n\nfunction gte() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _gte(n, t[0]);\n };\n }\n return _gte(arguments[0], arguments[1]);\n}\n\nfunction _lt(t, n) {\n return t < n;\n}\n\nfunction lt() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _lt(n, t[0]);\n };\n }\n return _lt(arguments[0], arguments[1]);\n}\n\nfunction _lte(t, n) {\n return t <= n;\n}\n\nfunction lte() {\n if (1 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _lte(n, t[0]);\n };\n }\n return _lte(arguments[0], arguments[1]);\n}\n\nfunction _clamp(t, n, r) {\n return Math.min(Math.max(t, n), r);\n}\n\nfunction clamp() {\n if (2 === arguments.length) {\n const t = arguments;\n return function fn(n) {\n return _clamp(n, t[0], t[1]);\n };\n }\n return _clamp(arguments[0], arguments[1], arguments[2]);\n}\n\nvar n = {\n __proto__: null,\n placeholder,\n pred,\n succ,\n add,\n subtract,\n multiply,\n divide,\n modulo,\n divideWithModulo,\n gt,\n gte,\n lt,\n lte,\n clamp\n};\n\nexport { pred as a, add as b, subtract as c, divide as d, modulo as e, divideWithModulo as f, gt as g, gte as h, n as i, lte as j, clamp as k, lt as l, multiply as m, placeholder as p, succ as s };\n","import { N, pipe } from \"@mobily/ts-belt\";\n\nexport const estEntreDeuxNombres = (nombre: number, min: number, max: number): boolean =>\n N.gte(nombre, min) && N.lt(nombre, max);\n\nexport const diviseParCent = (nombre: number | string): number => Number(nombre) / 100;\n\nexport const arrondisADeuxDecimales = (nombre: number | string) => pipe(Number(nombre), n => n.toFixed(2));\n\nexport const arrondisAZeroOuDeuxDecimales = (nombre: number | string): string =>\n pipe(Number(nombre), n => (n / Math.round(n)) === 1 ? n.toFixed(0) : n.toFixed(2));\n\nexport const inverseNombre = (nombre: number | string): number => Number(nombre) * -1;\n\nexport const formateEnEuros = (nombre: number | string): string => `${String(nombre)}€`;\n\nexport const diviseParCentEtFormateEnEuros = (nombre: number | string): string =>\n pipe(Number(nombre), diviseParCent, formateEnEuros);\n\nexport const diviseParCentEtArrondis = (nombre: number | string): string =>\n pipe(Number(nombre), diviseParCent, arrondisADeuxDecimales);\n"],"x_google_ignoreList":[0],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js b/web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js new file mode 100644 index 00000000..40be525a --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js @@ -0,0 +1,353 @@ +import { $ as Maybe, Q as right, X as Either, Z as left, b as ServerError, et as just, h as BadRequestError, tt as nothing, v as ForbiddenError, x as UnauthorizedError, y as NotFoundError } from "./dom.emspS_OW.js"; +import { r as ENTETE_WC_NONCE } from "./api.CM5TBNEA.js"; +import { t as M } from "./dist.CzYTlmnN.js"; + +//#region node_modules/purify-ts/esm/EitherAsync.js +var _a$1; +var helpers$1 = { + liftEither(either) { + if (either.isRight()) return Promise.resolve(either.extract()); + throw either.extract(); + }, + fromPromise(promise) { + return promise.then(helpers$1.liftEither); + }, + throwE(error) { + throw error; + } +}; +var EitherAsyncImpl = class { + constructor(runPromise) { + this.runPromise = runPromise; + this[_a$1] = "EitherAsync"; + this.then = (onfulfilled, onrejected) => { + return this.run().then(onfulfilled, onrejected); + }; + } + leftOrDefault(defaultValue) { + return this.run().then((x) => x.leftOrDefault(defaultValue)); + } + orDefault(defaultValue) { + return this.run().then((x) => x.orDefault(defaultValue)); + } + join() { + return EitherAsync(async (helpers$2) => { + const either = await this; + if (either.isRight()) { + const nestedEither = await either.extract(); + return helpers$2.liftEither(nestedEither); + } + return helpers$2.liftEither(either); + }); + } + ap(eitherF) { + return EitherAsync(async (helpers$2) => { + const otherValue = await eitherF; + if (otherValue.isRight()) { + const thisValue = await this.run(); + if (thisValue.isRight()) return otherValue.extract()(thisValue.extract()); + else return helpers$2.liftEither(thisValue); + } + return helpers$2.liftEither(otherValue); + }); + } + alt(other) { + return EitherAsync(async (helpers$2) => { + const thisValue = await this.run(); + if (thisValue.isRight()) return thisValue.extract(); + else { + const otherValue = await other; + return helpers$2.liftEither(otherValue); + } + }); + } + extend(f) { + return EitherAsync(async (helpers$2) => { + const either = await this.run(); + if (either.isRight()) { + const v = EitherAsync.liftEither(either); + return helpers$2.liftEither(right(f(v))); + } + return helpers$2.liftEither(either); + }); + } + async run() { + try { + return right(await this.runPromise(helpers$1)); + } catch (e) { + return left(e); + } + } + bimap(f, g) { + return EitherAsync(async (helpers$2) => { + const either = await this.run(); + try { + return await helpers$2.liftEither(either.bimap(f, g)); + } catch (e) { + throw await e; + } + }); + } + map(f) { + return EitherAsync((helpers$2) => this.runPromise(helpers$2).then(f)); + } + mapLeft(f) { + return EitherAsync(async (helpers$2) => { + try { + return await this.runPromise(helpers$2); + } catch (e) { + throw await f(e); + } + }); + } + chain(f) { + return EitherAsync(async (helpers$2) => { + const value = await this.runPromise(helpers$2); + return helpers$2.fromPromise(f(value)); + }); + } + chainLeft(f) { + return EitherAsync(async (helpers$2) => { + try { + return await this.runPromise(helpers$2); + } catch (e) { + return helpers$2.fromPromise(f(e)); + } + }); + } + toMaybeAsync() { + return MaybeAsync(async ({ liftMaybe }) => { + return liftMaybe((await this.run()).toMaybe()); + }); + } + swap() { + return EitherAsync(async (helpers$2) => { + const either = await this.run(); + if (either.isRight()) helpers$2.throwE(either.extract()); + return helpers$2.liftEither(right(either.extract())); + }); + } + ifLeft(effect) { + return EitherAsync(async (helpers$2) => { + const either = await this.run(); + either.ifLeft(effect); + return helpers$2.liftEither(either); + }); + } + ifRight(effect) { + return EitherAsync(async (helpers$2) => { + const either = await this.run(); + either.ifRight(effect); + return helpers$2.liftEither(either); + }); + } + void() { + return this.map((_) => {}); + } + caseOf(patterns) { + return this.run().then((x) => x.caseOf(patterns)); + } + finally(effect) { + return EitherAsync(({ fromPromise }) => fromPromise(this.run().finally(effect))); + } +}; +_a$1 = Symbol.toStringTag; +EitherAsyncImpl.prototype["fantasy-land/chain"] = EitherAsyncImpl.prototype.chain; +EitherAsyncImpl.prototype["fantasy-land/alt"] = EitherAsyncImpl.prototype.alt; +const EitherAsync = Object.assign((runPromise) => new EitherAsyncImpl(runPromise), { + fromPromise: (f) => EitherAsync(({ fromPromise: fP }) => fP(f())), + liftEither: (either) => EitherAsync(({ liftEither }) => liftEither(either)), + lefts: (list) => Promise.all(list.map((x) => x.run())).then(Either.lefts), + rights: (list) => Promise.all(list.map((x) => x.run())).then(Either.rights), + sequence: (eas) => EitherAsync(async (helpers$2) => { + let res = []; + for await (const e of eas) { + if (e.isLeft()) return helpers$2.liftEither(e); + res.push(e.extract()); + } + return helpers$2.liftEither(right(res)); + }), + all: (eas) => EitherAsync.fromPromise(async () => Promise.all(eas).then(Either.sequence)) +}); +EitherAsyncImpl.prototype.constructor = EitherAsync; + +//#endregion +//#region node_modules/purify-ts/esm/MaybeAsync.js +var _a; +var helpers = { + liftMaybe(maybe) { + if (maybe.isJust()) return Promise.resolve(maybe.extract()); + throw nothing; + }, + fromPromise(promise) { + return promise.then(helpers.liftMaybe); + } +}; +var MaybeAsyncImpl = class { + constructor(runPromise) { + this.runPromise = runPromise; + this[_a] = "MaybeAsync"; + } + orDefault(defaultValue) { + return this.run().then((x) => x.orDefault(defaultValue)); + } + join() { + return MaybeAsync(async (helpers$2) => { + const maybe = await this.run(); + if (maybe.isJust()) { + const nestedMaybe = await maybe.extract(); + return helpers$2.liftMaybe(nestedMaybe); + } + return helpers$2.liftMaybe(nothing); + }); + } + ap(maybeF) { + return MaybeAsync(async (helpers$2) => { + const otherValue = await maybeF; + if (otherValue.isJust()) { + const thisValue = await this.run(); + if (thisValue.isJust()) return otherValue.extract()(thisValue.extract()); + else return helpers$2.liftMaybe(nothing); + } + return helpers$2.liftMaybe(nothing); + }); + } + alt(other) { + return MaybeAsync(async (helpers$2) => { + const thisValue = await this.run(); + if (thisValue.isJust()) return thisValue.extract(); + else { + const otherValue = await other; + return helpers$2.liftMaybe(otherValue); + } + }); + } + extend(f) { + return MaybeAsync(async (helpers$2) => { + const maybe = await this.run(); + if (maybe.isJust()) { + const v = MaybeAsync.liftMaybe(maybe); + return helpers$2.liftMaybe(just(f(v))); + } + return helpers$2.liftMaybe(nothing); + }); + } + filter(pred) { + return MaybeAsync(async (helpers$2) => { + const value = await this.run(); + return helpers$2.liftMaybe(value.filter(pred)); + }); + } + async run() { + try { + return just(await this.runPromise(helpers)); + } catch { + return nothing; + } + } + map(f) { + return MaybeAsync((helpers$2) => this.runPromise(helpers$2).then(f)); + } + chain(f) { + return MaybeAsync(async (helpers$2) => { + const value = await this.runPromise(helpers$2); + return helpers$2.fromPromise(f(value)); + }); + } + toEitherAsync(error) { + return EitherAsync(async ({ liftEither }) => { + return liftEither((await this.run()).toEither(error)); + }); + } + ifJust(effect) { + return MaybeAsync(async (helpers$2) => { + const maybe = await this.run(); + maybe.ifJust(effect); + return helpers$2.liftMaybe(maybe); + }); + } + ifNothing(effect) { + return MaybeAsync(async (helpers$2) => { + const maybe = await this.run(); + maybe.ifNothing(effect); + return helpers$2.liftMaybe(maybe); + }); + } + void() { + return this.map((_) => {}); + } + caseOf(patterns) { + return this.run().then((x) => x.caseOf(patterns)); + } + finally(effect) { + return MaybeAsync(({ fromPromise }) => fromPromise(this.run().finally(effect))); + } + then(onfulfilled, onrejected) { + return this.run().then(onfulfilled, onrejected); + } +}; +_a = Symbol.toStringTag; +MaybeAsyncImpl.prototype["fantasy-land/chain"] = MaybeAsyncImpl.prototype.chain; +MaybeAsyncImpl.prototype["fantasy-land/filter"] = MaybeAsyncImpl.prototype.filter; +MaybeAsyncImpl.prototype["fantasy-land/alt"] = MaybeAsyncImpl.prototype.alt; +const MaybeAsync = Object.assign((runPromise) => new MaybeAsyncImpl(runPromise), { + catMaybes: (list) => Promise.all(list).then(Maybe.catMaybes), + fromPromise: (f) => MaybeAsync(({ fromPromise: fP }) => fP(f())), + liftMaybe: (maybe) => MaybeAsync(({ liftMaybe }) => liftMaybe(maybe)) +}); +MaybeAsyncImpl.prototype.constructor = MaybeAsync; + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/lib/reseau.ts +const getBackendAvecParametresUrl = (args) => fetch(`${args.route}?${args.searchParams}`, { + credentials: "same-origin", + headers: { + Accept: "application/json", + "Content-Type": "application/json", + [ENTETE_WC_NONCE]: args.nonce, + ...args.authString && { Authorization: `Basic ${args.authString}` } + }, + method: "GET", + mode: "same-origin", + signal: AbortSignal.timeout(5e3) +}); +const postBackend = (args) => fetch(args.route, { + body: args.corps, + credentials: "same-origin", + headers: { + Accept: "application/json", + "Content-Type": "application/json", + [ENTETE_WC_NONCE]: args.nonce, + ...args.authString && { Authorization: `Basic ${args.authString}` } + }, + method: "POST", + mode: "same-origin", + signal: AbortSignal.timeout(5e3) +}); +const prefilledPostBackend = (nonce, authString) => (route, body, needsAuthString) => fetch(route, { + body, + credentials: "same-origin", + headers: { + Accept: "application/json", + "Content-Type": "application/json", + [ENTETE_WC_NONCE]: nonce, + ...authString && needsAuthString && { Authorization: `Basic ${authString}` } + }, + method: "POST", + mode: "same-origin", + signal: AbortSignal.timeout(5e3) +}); +const safeFetch = (f) => EitherAsync(async () => await f); +const newPartialResponse = async (reponse) => { + return { + body: await reponse.json(), + status: reponse.status + }; +}; +const traiteErreursBackendWooCommerce = (rs) => { + return M(rs).with({ status: 400 }, () => new BadRequestError()).with({ status: 401 }, () => new UnauthorizedError()).with({ status: 403 }, () => new ForbiddenError()).with({ status: 404 }, () => new NotFoundError()).with({ status: 500 }, () => new ServerError()).otherwise((rs$1) => new Error(String(rs$1.status))); +}; + +//#endregion +export { safeFetch as a, prefilledPostBackend as i, newPartialResponse as n, traiteErreursBackendWooCommerce as o, postBackend as r, EitherAsync as s, getBackendAvecParametresUrl as t }; +//# sourceMappingURL=reseau.BY4MrTI9.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js.map b/web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js.map new file mode 100644 index 00000000..7ee88635 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/reseau.BY4MrTI9.js.map @@ -0,0 +1 @@ +{"version":3,"file":"reseau.BY4MrTI9.js","names":["_a","helpers","Right","Left","Nothing","helpers","Just"],"sources":["../../../../../../node_modules/purify-ts/esm/EitherAsync.js","../../../../../../node_modules/purify-ts/esm/MaybeAsync.js","../../src/scripts/lib/reseau.ts"],"sourcesContent":["var _a;\nimport { Either, Left, Right } from './Either.js';\nimport { MaybeAsync } from './MaybeAsync.js';\nconst helpers = {\n liftEither(either) {\n if (either.isRight()) {\n return Promise.resolve(either.extract());\n }\n throw either.extract();\n },\n fromPromise(promise) {\n return promise.then(helpers.liftEither);\n },\n throwE(error) {\n throw error;\n }\n};\nclass EitherAsyncImpl {\n constructor(runPromise) {\n this.runPromise = runPromise;\n this[_a] = 'EitherAsync';\n this.then = (onfulfilled, onrejected) => {\n return this.run().then(onfulfilled, onrejected);\n };\n }\n leftOrDefault(defaultValue) {\n return this.run().then((x) => x.leftOrDefault(defaultValue));\n }\n orDefault(defaultValue) {\n return this.run().then((x) => x.orDefault(defaultValue));\n }\n join() {\n return EitherAsync(async (helpers) => {\n const either = await this;\n if (either.isRight()) {\n const nestedEither = await either.extract();\n return helpers.liftEither(nestedEither);\n }\n return helpers.liftEither(either);\n });\n }\n ap(eitherF) {\n return EitherAsync(async (helpers) => {\n const otherValue = await eitherF;\n if (otherValue.isRight()) {\n const thisValue = await this.run();\n if (thisValue.isRight()) {\n return otherValue.extract()(thisValue.extract());\n }\n else {\n return helpers.liftEither(thisValue);\n }\n }\n return helpers.liftEither(otherValue);\n });\n }\n alt(other) {\n return EitherAsync(async (helpers) => {\n const thisValue = await this.run();\n if (thisValue.isRight()) {\n return thisValue.extract();\n }\n else {\n const otherValue = await other;\n return helpers.liftEither(otherValue);\n }\n });\n }\n extend(f) {\n return EitherAsync(async (helpers) => {\n const either = await this.run();\n if (either.isRight()) {\n const v = EitherAsync.liftEither(either);\n return helpers.liftEither(Right(f(v)));\n }\n return helpers.liftEither(either);\n });\n }\n async run() {\n try {\n return Right(await this.runPromise(helpers));\n }\n catch (e) {\n return Left(e);\n }\n }\n bimap(f, g) {\n return EitherAsync(async (helpers) => {\n const either = await this.run();\n try {\n return (await helpers.liftEither(either.bimap(f, g)));\n }\n catch (e) {\n throw await e;\n }\n });\n }\n map(f) {\n return EitherAsync((helpers) => this.runPromise(helpers).then(f));\n }\n mapLeft(f) {\n return EitherAsync(async (helpers) => {\n try {\n return await this.runPromise(helpers);\n }\n catch (e) {\n throw await f(e);\n }\n });\n }\n chain(f) {\n return EitherAsync(async (helpers) => {\n const value = await this.runPromise(helpers);\n return helpers.fromPromise(f(value));\n });\n }\n chainLeft(f) {\n return EitherAsync(async (helpers) => {\n try {\n return await this.runPromise(helpers);\n }\n catch (e) {\n return helpers.fromPromise(f(e));\n }\n });\n }\n toMaybeAsync() {\n return MaybeAsync(async ({ liftMaybe }) => {\n const either = await this.run();\n return liftMaybe(either.toMaybe());\n });\n }\n swap() {\n return EitherAsync(async (helpers) => {\n const either = await this.run();\n if (either.isRight())\n helpers.throwE(either.extract());\n return helpers.liftEither(Right(either.extract()));\n });\n }\n ifLeft(effect) {\n return EitherAsync(async (helpers) => {\n const either = await this.run();\n either.ifLeft(effect);\n return helpers.liftEither(either);\n });\n }\n ifRight(effect) {\n return EitherAsync(async (helpers) => {\n const either = await this.run();\n either.ifRight(effect);\n return helpers.liftEither(either);\n });\n }\n void() {\n return this.map((_) => { });\n }\n caseOf(patterns) {\n return this.run().then((x) => x.caseOf(patterns));\n }\n finally(effect) {\n return EitherAsync(({ fromPromise }) => fromPromise(this.run().finally(effect)));\n }\n}\n_a = Symbol.toStringTag;\nEitherAsyncImpl.prototype['fantasy-land/chain'] =\n EitherAsyncImpl.prototype.chain;\nEitherAsyncImpl.prototype['fantasy-land/alt'] = EitherAsyncImpl.prototype.alt;\nexport const EitherAsync = Object.assign((runPromise) => new EitherAsyncImpl(runPromise), {\n fromPromise: (f) => EitherAsync(({ fromPromise: fP }) => fP(f())),\n liftEither: (either) => EitherAsync(({ liftEither }) => liftEither(either)),\n lefts: (list) => Promise.all(list.map((x) => x.run())).then(Either.lefts),\n rights: (list) => Promise.all(list.map((x) => x.run())).then(Either.rights),\n sequence: (eas) => EitherAsync(async (helpers) => {\n let res = [];\n for await (const e of eas) {\n if (e.isLeft()) {\n return helpers.liftEither(e);\n }\n res.push(e.extract());\n }\n return helpers.liftEither(Right(res));\n }),\n all: (eas) => EitherAsync.fromPromise(async () => Promise.all(eas).then(Either.sequence))\n});\nEitherAsyncImpl.prototype.constructor = EitherAsync;\n","var _a;\nimport { Maybe, Just, Nothing } from './Maybe.js';\nimport { EitherAsync } from './EitherAsync.js';\nconst helpers = {\n liftMaybe(maybe) {\n if (maybe.isJust()) {\n return Promise.resolve(maybe.extract());\n }\n throw Nothing;\n },\n fromPromise(promise) {\n return promise.then(helpers.liftMaybe);\n }\n};\nclass MaybeAsyncImpl {\n constructor(runPromise) {\n this.runPromise = runPromise;\n this[_a] = 'MaybeAsync';\n }\n orDefault(defaultValue) {\n return this.run().then((x) => x.orDefault(defaultValue));\n }\n join() {\n return MaybeAsync(async (helpers) => {\n const maybe = await this.run();\n if (maybe.isJust()) {\n const nestedMaybe = await maybe.extract();\n return helpers.liftMaybe(nestedMaybe);\n }\n return helpers.liftMaybe(Nothing);\n });\n }\n ap(maybeF) {\n return MaybeAsync(async (helpers) => {\n const otherValue = await maybeF;\n if (otherValue.isJust()) {\n const thisValue = await this.run();\n if (thisValue.isJust()) {\n return otherValue.extract()(thisValue.extract());\n }\n else {\n return helpers.liftMaybe(Nothing);\n }\n }\n return helpers.liftMaybe(Nothing);\n });\n }\n alt(other) {\n return MaybeAsync(async (helpers) => {\n const thisValue = await this.run();\n if (thisValue.isJust()) {\n return thisValue.extract();\n }\n else {\n const otherValue = await other;\n return helpers.liftMaybe(otherValue);\n }\n });\n }\n extend(f) {\n return MaybeAsync(async (helpers) => {\n const maybe = await this.run();\n if (maybe.isJust()) {\n const v = MaybeAsync.liftMaybe(maybe);\n return helpers.liftMaybe(Just(f(v)));\n }\n return helpers.liftMaybe(Nothing);\n });\n }\n filter(pred) {\n return MaybeAsync(async (helpers) => {\n const value = await this.run();\n return helpers.liftMaybe(value.filter(pred));\n });\n }\n async run() {\n try {\n return Just(await this.runPromise(helpers));\n }\n catch {\n return Nothing;\n }\n }\n map(f) {\n return MaybeAsync((helpers) => this.runPromise(helpers).then(f));\n }\n chain(f) {\n return MaybeAsync(async (helpers) => {\n const value = await this.runPromise(helpers);\n return helpers.fromPromise(f(value));\n });\n }\n toEitherAsync(error) {\n return EitherAsync(async ({ liftEither }) => {\n const maybe = await this.run();\n return liftEither(maybe.toEither(error));\n });\n }\n ifJust(effect) {\n return MaybeAsync(async (helpers) => {\n const maybe = await this.run();\n maybe.ifJust(effect);\n return helpers.liftMaybe(maybe);\n });\n }\n ifNothing(effect) {\n return MaybeAsync(async (helpers) => {\n const maybe = await this.run();\n maybe.ifNothing(effect);\n return helpers.liftMaybe(maybe);\n });\n }\n void() {\n return this.map((_) => { });\n }\n caseOf(patterns) {\n return this.run().then((x) => x.caseOf(patterns));\n }\n finally(effect) {\n return MaybeAsync(({ fromPromise }) => fromPromise(this.run().finally(effect)));\n }\n then(onfulfilled, onrejected) {\n return this.run().then(onfulfilled, onrejected);\n }\n}\n_a = Symbol.toStringTag;\nMaybeAsyncImpl.prototype['fantasy-land/chain'] = MaybeAsyncImpl.prototype.chain;\nMaybeAsyncImpl.prototype['fantasy-land/filter'] =\n MaybeAsyncImpl.prototype.filter;\nMaybeAsyncImpl.prototype['fantasy-land/alt'] = MaybeAsyncImpl.prototype.alt;\nexport const MaybeAsync = Object.assign((runPromise) => new MaybeAsyncImpl(runPromise), {\n catMaybes: (list) => Promise.all(list).then(Maybe.catMaybes),\n fromPromise: (f) => MaybeAsync(({ fromPromise: fP }) => fP(f())),\n liftMaybe: (maybe) => MaybeAsync(({ liftMaybe }) => liftMaybe(maybe))\n});\nMaybeAsyncImpl.prototype.constructor = MaybeAsync;\n","import { pipe } from \"@mobily/ts-belt\";\nimport { EitherAsync } from \"purify-ts\";\nimport { match, P } from \"ts-pattern\";\nimport { type GenericSchema, parse } from \"valibot\";\n\nimport type { HttpCodeErrors, SimplifiedResponse } from \"./types/reseau\";\n\nimport { ENTETE_WC_NONCE } from \"../constantes/api.ts\";\nimport {\n BadRequestError,\n ErreurInconnue,\n ForbiddenError,\n leveBadRequestError,\n leveErreur,\n leveNotFoundError,\n leveUnauthorizedError,\n NotFoundError,\n ServerError,\n UnauthorizedError,\n type UnknownError,\n} from \"./erreurs.ts\";\nimport { estWCError } from \"./schemas/api/erreurs.ts\";\n\n// Types\n\ntype ArgumentsDeleteBackendWC = {\n authString?: string;\n /** Une chaîne de caractères généré par le backend et à joindre à chaque requête pour l'authentifier. */\n nonce: string;\n /** La route, ou chemin, de l'API à demander au backend. */\n route: string;\n};\n\ntype ArgumentsGetBackendWC = {\n authString?: string;\n /** Une chaîne de caractères généré par le backend et à joindre à chaque requête pour l'authentifier. */\n nonce: string;\n /** La route, ou chemin, de l'API à demander au backend. */\n route: string;\n /** Paramètres de recherche (« query args ») à injecter dans l'URL de la requête. */\n searchParams?: string;\n};\n\ntype ArgumentsPostBackendWC = {\n authString?: string;\n /** Le corps de la requête (ses arguments). */\n corps: BodyInit;\n /** Une chaîne de caractères généré par le backend et à joindre à chaque requête pour l'authentifier. */\n nonce: string;\n /** La route, ou chemin, de l'API à demander au backend. */\n route: string;\n};\n\n// fetch\n\nexport const getBackend = (args: ArgumentsGetBackendWC): Promise =>\n fetch(\n args.route,\n {\n credentials: \"same-origin\",\n headers: {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n [ENTETE_WC_NONCE]: args.nonce,\n // Ajoute conditionnellement l'en-tête « Authorization »\n ...(args.authString && { Authorization: `Basic ${args.authString}` }),\n },\n method: \"GET\",\n mode: \"same-origin\",\n signal: AbortSignal.timeout(5000),\n },\n );\n\nexport const getBackendAvecParametresUrl = (args: ArgumentsGetBackendWC): Promise =>\n fetch(\n `${args.route}?${args.searchParams}`,\n {\n credentials: \"same-origin\",\n headers: {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n [ENTETE_WC_NONCE]: args.nonce,\n // Ajoute conditionnellement l'en-tête « Authorization »\n ...(args.authString && { Authorization: `Basic ${args.authString}` }),\n },\n method: \"GET\",\n mode: \"same-origin\",\n signal: AbortSignal.timeout(5000),\n },\n );\n\nexport const deleteBackend = (args: ArgumentsDeleteBackendWC): Promise =>\n fetch(\n args.route,\n {\n credentials: \"same-origin\",\n headers: {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n [ENTETE_WC_NONCE]: args.nonce,\n // Ajoute conditionnellement l'en-tête « Authorization »\n ...(args.authString && { Authorization: `Basic ${args.authString}` }),\n },\n method: \"DELETE\",\n mode: \"same-origin\",\n signal: AbortSignal.timeout(5000),\n },\n );\n\nexport const postBackend = (args: ArgumentsPostBackendWC): Promise =>\n fetch(\n args.route,\n {\n body: args.corps,\n credentials: \"same-origin\",\n headers: {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n [ENTETE_WC_NONCE]: args.nonce,\n // Ajoute conditionnellement l'en-tête « Authorization »\n ...(args.authString && { Authorization: `Basic ${args.authString}` }),\n },\n method: \"POST\",\n mode: \"same-origin\",\n signal: AbortSignal.timeout(5000),\n },\n );\n\nexport const prefilledPostBackend =\n (nonce: string, authString?: string) =>\n (route: string, body: BodyInit, needsAuthString: boolean): Promise =>\n fetch(\n route,\n {\n body: body,\n credentials: \"same-origin\",\n headers: {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n [ENTETE_WC_NONCE]: nonce,\n ...(authString && needsAuthString && { Authorization: `Basic ${authString}` }),\n },\n method: \"POST\",\n mode: \"same-origin\",\n signal: AbortSignal.timeout(5000),\n },\n );\n\nexport const safeFetch = (f: Promise): EitherAsync =>\n EitherAsync(async () => await f);\n\n// TODO: Ne traite pas du tout les Erreurs\n// TODO: Utiliser un Either\nexport const traiteReponseBackendWCSelonCodesHTTP = >(\n corpsReponse: unknown,\n schemaReponse: S,\n): R =>\n match(corpsReponse)\n // Réponses problématiques\n .with({ body: P.select(), status: 400 }, estWCError, leveBadRequestError)\n .with({ body: P.select(), status: 401 }, estWCError, leveUnauthorizedError)\n .with({ body: P.select(), status: 404 }, estWCError, leveNotFoundError)\n // Réponse OK (201)\n .with(P._, corpsOkInconnu => parse(schemaReponse, corpsOkInconnu))\n // Réponses inconnues\n .otherwise(e => pipe(e, ErreurInconnue, leveErreur));\n\n// Réponses Simplifiées\nexport const newPartialResponse = async (reponse: Response): Promise => {\n return {\n body: await reponse.json(),\n status: reponse.status,\n };\n};\n\nexport const traiteErreursBackendWooCommerce = (rs: SimplifiedResponse): HttpCodeErrors => {\n return match(rs)\n .with({ status: 400 }, () => new BadRequestError())\n .with({ status: 401 }, () => new UnauthorizedError())\n .with({ status: 403 }, () => new ForbiddenError())\n .with({ status: 404 }, () => new NotFoundError())\n .with({ status: 500 }, () => new ServerError())\n .otherwise(rs => new Error(String(rs.status)));\n};\n"],"x_google_ignoreList":[0,1],"mappings":"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"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js new file mode 100644 index 00000000..96665e39 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js @@ -0,0 +1,32 @@ +import "./journalisation.CEgm28xa.js"; +import "./exports.CurVqjr0.js"; +import { At as DOM_BOUTON_PANIER, a as mustGetEleInDocument, ut as ATTRIBUT_CONTIENT_ARTICLES } from "./dom.emspS_OW.js"; +import { a as valideMessageMajBoutonPanier, f as NOM_CANAL_BOUTON_PANIER } from "./messages.CqHLtCes.js"; +import "./validation.CYJDC5vQ.js"; + +//#region web/app/themes/haiku-atelier-2024/src/scripts/scripts-bouton-panier.ts +/** +* Initialise les interactions et la mise à jour du bouton « Panier » contenant le nombre d'articles dans le Panier. +* +* @returns void +*/ +var initialiseBoutonPanier = () => { + /** Le « Bouton » vers le Panier avec un indicateur de la quantité de Produits ajoutés. */ + const BOUTON_PANIER = mustGetEleInDocument(DOM_BOUTON_PANIER); + const CANAL_BOUTON_PANIER = new BroadcastChannel(NOM_CANAL_BOUTON_PANIER); + CANAL_BOUTON_PANIER.onmessage = (evenementMessage) => { + valideMessageMajBoutonPanier(evenementMessage).ifRight((message) => { + BOUTON_PANIER.textContent = `cart (${String(message.donnees.quantiteProduits)})`; + BOUTON_PANIER.setAttribute(ATTRIBUT_CONTIENT_ARTICLES, String(message.donnees.quantiteProduits > 0)); + }); + }; + document.addEventListener("visibilitychange", () => { + CANAL_BOUTON_PANIER.close(); + }); +}; +document.addEventListener("DOMContentLoaded", () => { + initialiseBoutonPanier(); +}); + +//#endregion +//# sourceMappingURL=scripts-bouton-panier.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js.map b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js.map new file mode 100644 index 00000000..40cf4d46 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-panier.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scripts-bouton-panier.js","names":["BOUTON_PANIER: HTMLAnchorElement","CANAL_BOUTON_PANIER: BroadcastChannel"],"sources":["../../src/scripts/scripts-bouton-panier.ts"],"sourcesContent":["/**\n * Scripts pour la mise à jour trans-fenêtres/trans-onglets du Bouton du Panier.\n */\n\nimport type { MessageMajBoutonPanier } from \"./lib/types/messages\";\n\nimport { ATTRIBUT_CONTIENT_ARTICLES, DOM_BOUTON_PANIER } from \"./constantes/dom.ts\";\nimport { NOM_CANAL_BOUTON_PANIER } from \"./constantes/messages.ts\";\nimport { mustGetEleInDocument } from \"./lib/dom.ts\";\nimport { valideMessageMajBoutonPanier } from \"./lib/messages.ts\";\n\n/**\n * Initialise les interactions et la mise à jour du bouton « Panier » contenant le nombre d'articles dans le Panier.\n *\n * @returns void\n */\nconst initialiseBoutonPanier = (): void => {\n /** Le « Bouton » vers le Panier avec un indicateur de la quantité de Produits ajoutés. */\n const BOUTON_PANIER: HTMLAnchorElement = mustGetEleInDocument(DOM_BOUTON_PANIER);\n const CANAL_BOUTON_PANIER: BroadcastChannel = new BroadcastChannel(NOM_CANAL_BOUTON_PANIER);\n\n CANAL_BOUTON_PANIER.onmessage = (evenementMessage: MessageEvent): void => {\n valideMessageMajBoutonPanier(evenementMessage)\n // Met à jour le Bouton du Panier\n .ifRight((message: MessageMajBoutonPanier) => {\n BOUTON_PANIER.textContent = `cart (${String(message.donnees.quantiteProduits)})`;\n BOUTON_PANIER.setAttribute(ATTRIBUT_CONTIENT_ARTICLES, String(message.donnees.quantiteProduits > 0));\n });\n };\n\n // Ferme le BroadcastChannel à la fermeture de la page\n document.addEventListener(\"visibilitychange\", (): void => {\n CANAL_BOUTON_PANIER.close();\n });\n};\n\ndocument.addEventListener(\"DOMContentLoaded\", (): void => {\n initialiseBoutonPanier();\n});\n"],"mappings":";;;;;;;;;;;;AAgBA,IAAM,+BAAqC;;CAEzC,MAAMA,gBAAmC,qBAAwC,kBAAkB;CACnG,MAAMC,sBAAwC,IAAI,iBAAiB,wBAAwB;AAE3F,qBAAoB,aAAa,qBAAkD;AACjF,+BAA6B,iBAAiB,CAE3C,SAAS,YAAoC;AAC5C,iBAAc,cAAc,SAAS,OAAO,QAAQ,QAAQ,iBAAiB,CAAC;AAC9E,iBAAc,aAAa,4BAA4B,OAAO,QAAQ,QAAQ,mBAAmB,EAAE,CAAC;IACpG;;AAIN,UAAS,iBAAiB,0BAAgC;AACxD,sBAAoB,OAAO;GAC3B;;AAGJ,SAAS,iBAAiB,0BAAgC;AACxD,yBAAwB;EACxB"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js new file mode 100644 index 00000000..f26bc2d0 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js @@ -0,0 +1,87 @@ +import "./journalisation.CEgm28xa.js"; +import { dt as pipe } from "./exports.CurVqjr0.js"; +import { _n as head, a as mustGetEleInDocument, at as ATTRIBUT_ARIA_HIDDEN, bt as ATTRIBUT_TABINDEX, kt as DOM_BOUTON_MENU_MOBILE, nt as ATTRIBUT_ACTIF } from "./dom.emspS_OW.js"; +import "./belt_Option-91f3b350.CMbgtZ-W.js"; +import { n as tap } from "./index-c1cc4c86.D2nZEikK.js"; + +//#region web/app/themes/haiku-atelier-2024/src/scripts/scripts-bouton-retour-sommet.ts +var E = { + BOUTON_MENU_MOBILE: mustGetEleInDocument(DOM_BOUTON_MENU_MOBILE), + BOUTON_RETOUR_SOMMET: mustGetEleInDocument("#bouton-retour-haut"), + CORPS_HTML: mustGetEleInDocument("body"), + IMAGE_BOUTON: mustGetEleInDocument("#bouton-retour-haut img") +}; +/** Le ratio minimum hauteur de page/hauteur de la fenêtre à atteindre pour que le Bouton soit nécessaire. */ +var RATIO_MINIMUM_PAGE_PAR_FENETRE = 3; +/** Le ratio actuel hauteur de page/hauteur de la fenêtre. */ +var ratioActuel = E.CORPS_HTML.getBoundingClientRect().height / window.innerHeight; +/** La position actuelle du défilement vertical dans la page. */ +var defilementY = window.scrollY; +/** Indique qu'une étape de rafraîchissement via `requestAnimationFrame` a déjà été demandée. */ +var etapePlanifiee = false; +/** +* Retourne la position du défilement vertical dans la page. +* +* @returns Un nombre en pixels. +*/ +var majDefilementY = () => window.scrollY; +/** +* @param estVisible +* @returns void +*/ +var majVisibiliteBouton = (estVisible) => { + if (estVisible) { + E.BOUTON_RETOUR_SOMMET.setAttribute(ATTRIBUT_ACTIF, ""); + E.BOUTON_RETOUR_SOMMET.setAttribute(ATTRIBUT_TABINDEX, "99"); + E.IMAGE_BOUTON.setAttribute(ATTRIBUT_ARIA_HIDDEN, "false"); + } else { + E.BOUTON_RETOUR_SOMMET.removeAttribute(ATTRIBUT_ACTIF); + E.BOUTON_RETOUR_SOMMET.setAttribute(ATTRIBUT_TABINDEX, "-2"); + E.IMAGE_BOUTON.setAttribute(ATTRIBUT_ARIA_HIDDEN, "true"); + } + etapePlanifiee = false; +}; +/** +* Initialise le cycle de mises à jour du Bouton en fonction de la position du défilement dans la page et le recalcul +* de ces données au redimensionnement de la fenêtre. +* +* @returns void +*/ +var initialiseObservationFenetre = () => { + window.addEventListener("scroll", () => { + defilementY = majDefilementY(); + if (ratioActuel < RATIO_MINIMUM_PAGE_PAR_FENETRE) return; + if (etapePlanifiee) return; + etapePlanifiee = true; + requestAnimationFrame(() => majVisibiliteBouton(defilementY > window.innerHeight * RATIO_MINIMUM_PAGE_PAR_FENETRE)); + }); + new ResizeObserver((entrees) => { + pipe(head(entrees), tap((_) => { + ratioActuel = E.CORPS_HTML.getBoundingClientRect().height / window.innerHeight; + defilementY = majDefilementY(); + })); + }).observe(E.CORPS_HTML); + majVisibiliteBouton(defilementY > window.innerHeight * RATIO_MINIMUM_PAGE_PAR_FENETRE); +}; +/** +* Navigue au sommet de la page et focus sur le premier élément de la page qui peut le recevoir. +* +* @returns void +*/ +var initialiseBoutonRetourSommet = () => { + E.BOUTON_RETOUR_SOMMET.addEventListener("click", (evenement) => { + evenement.preventDefault(); + window.scrollTo({ + behavior: "smooth", + top: 0 + }); + E.BOUTON_MENU_MOBILE.focus({ preventScroll: true }); + }); +}; +document.addEventListener("DOMContentLoaded", () => { + initialiseBoutonRetourSommet(); + initialiseObservationFenetre(); +}); + +//#endregion +//# sourceMappingURL=scripts-bouton-retour-sommet.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js.map b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js.map new file mode 100644 index 00000000..62d01661 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-bouton-retour-sommet.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scripts-bouton-retour-sommet.js","names":[],"sources":["../../src/scripts/scripts-bouton-retour-sommet.ts"],"sourcesContent":["/** Scripts pour le bouton « Retour au sommet (de la page). » */\n\nimport { pipe } from \"@mobily/ts-belt\";\nimport { head as arrayHead } from \"@mobily/ts-belt/Array\";\nimport { tap as optionTap } from \"@mobily/ts-belt/Option\";\n\nimport { ATTRIBUT_ACTIF, ATTRIBUT_ARIA_HIDDEN, ATTRIBUT_TABINDEX, DOM_BOUTON_MENU_MOBILE } from \"./constantes/dom\";\nimport { mustGetEleInDocument } from \"./lib/dom\";\n\nconst E = {\n BOUTON_MENU_MOBILE: mustGetEleInDocument(DOM_BOUTON_MENU_MOBILE),\n BOUTON_RETOUR_SOMMET: mustGetEleInDocument(\"#bouton-retour-haut\"),\n CORPS_HTML: mustGetEleInDocument(\"body\"),\n IMAGE_BOUTON: mustGetEleInDocument(\"#bouton-retour-haut img\"),\n};\n\n/** Le ratio minimum hauteur de page/hauteur de la fenêtre à atteindre pour que le Bouton soit nécessaire. */\nconst RATIO_MINIMUM_PAGE_PAR_FENETRE = 3;\n\n/** Le ratio actuel hauteur de page/hauteur de la fenêtre. */\nlet ratioActuel = E.CORPS_HTML.getBoundingClientRect().height / window.innerHeight;\n/** La position actuelle du défilement vertical dans la page. */\nlet defilementY = window.scrollY;\n/** Indique qu'une étape de rafraîchissement via `requestAnimationFrame` a déjà été demandée. */\nlet etapePlanifiee = false;\n\n/**\n * Retourne la position du défilement vertical dans la page.\n *\n * @returns Un nombre en pixels.\n */\nconst majDefilementY = (): number => window.scrollY;\n\n/**\n * @param estVisible\n * @returns void\n */\nconst majVisibiliteBouton = (estVisible: boolean): void => {\n if (estVisible) {\n E.BOUTON_RETOUR_SOMMET.setAttribute(ATTRIBUT_ACTIF, \"\");\n E.BOUTON_RETOUR_SOMMET.setAttribute(ATTRIBUT_TABINDEX, \"99\");\n E.IMAGE_BOUTON.setAttribute(ATTRIBUT_ARIA_HIDDEN, \"false\");\n } else {\n E.BOUTON_RETOUR_SOMMET.removeAttribute(ATTRIBUT_ACTIF);\n E.BOUTON_RETOUR_SOMMET.setAttribute(ATTRIBUT_TABINDEX, \"-2\");\n E.IMAGE_BOUTON.setAttribute(ATTRIBUT_ARIA_HIDDEN, \"true\");\n }\n etapePlanifiee = false;\n};\n\n/**\n * Initialise le cycle de mises à jour du Bouton en fonction de la position du défilement dans la page et le recalcul\n * de ces données au redimensionnement de la fenêtre.\n *\n * @returns void\n */\nconst initialiseObservationFenetre = (): void => {\n window.addEventListener(\"scroll\", (): void => {\n // Met à jour la valeur du défilement vertical dans la page\n defilementY = majDefilementY();\n // Vérifie que le Ratio soit le bon\n if (ratioActuel < RATIO_MINIMUM_PAGE_PAR_FENETRE) return;\n // Attend la prochaine étape\n if (etapePlanifiee) return;\n\n etapePlanifiee = true;\n requestAnimationFrame((): void =>\n majVisibiliteBouton(defilementY > (window.innerHeight * RATIO_MINIMUM_PAGE_PAR_FENETRE))\n );\n });\n\n new ResizeObserver((entrees: Array): void => {\n pipe(\n arrayHead(entrees),\n optionTap((_): void => {\n ratioActuel = E.CORPS_HTML.getBoundingClientRect().height / window.innerHeight;\n defilementY = majDefilementY();\n }),\n );\n }).observe(E.CORPS_HTML);\n\n // Déclenche la première mise à jour\n majVisibiliteBouton(defilementY > window.innerHeight * RATIO_MINIMUM_PAGE_PAR_FENETRE);\n};\n\n/**\n * Navigue au sommet de la page et focus sur le premier élément de la page qui peut le recevoir.\n *\n * @returns void\n */\nconst initialiseBoutonRetourSommet = (): void => {\n E.BOUTON_RETOUR_SOMMET.addEventListener(\"click\", (evenement: Event): void => {\n evenement.preventDefault();\n\n window.scrollTo({ behavior: \"smooth\", top: 0 });\n E.BOUTON_MENU_MOBILE.focus({ preventScroll: true });\n });\n};\n\ndocument.addEventListener(\"DOMContentLoaded\", (): void => {\n initialiseBoutonRetourSommet();\n initialiseObservationFenetre();\n});\n"],"mappings":";;;;;;;AASA,IAAM,IAAI;CACR,oBAAoB,qBAAwC,uBAAuB;CACnF,sBAAsB,qBAAwC,sBAAsB;CACpF,YAAY,qBAAsC,OAAO;CACzD,cAAc,qBAAuC,0BAA0B;CAChF;;AAGD,IAAM,iCAAiC;;AAGvC,IAAI,cAAc,EAAE,WAAW,uBAAuB,CAAC,SAAS,OAAO;;AAEvE,IAAI,cAAc,OAAO;;AAEzB,IAAI,iBAAiB;;;;;;AAOrB,IAAM,uBAA+B,OAAO;;;;;AAM5C,IAAM,uBAAuB,eAA8B;AACzD,KAAI,YAAY;AACd,IAAE,qBAAqB,aAAa,gBAAgB,GAAG;AACvD,IAAE,qBAAqB,aAAa,mBAAmB,KAAK;AAC5D,IAAE,aAAa,aAAa,sBAAsB,QAAQ;QACrD;AACL,IAAE,qBAAqB,gBAAgB,eAAe;AACtD,IAAE,qBAAqB,aAAa,mBAAmB,KAAK;AAC5D,IAAE,aAAa,aAAa,sBAAsB,OAAO;;AAE3D,kBAAiB;;;;;;;;AASnB,IAAM,qCAA2C;AAC/C,QAAO,iBAAiB,gBAAsB;AAE5C,gBAAc,gBAAgB;AAE9B,MAAI,cAAc,+BAAgC;AAElD,MAAI,eAAgB;AAEpB,mBAAiB;AACjB,8BACE,oBAAoB,cAAe,OAAO,cAAc,+BAAgC,CACzF;GACD;AAEF,KAAI,gBAAgB,YAA8C;AAChE,OACE,KAAU,QAAQ,EAClB,KAAW,MAAY;AACrB,iBAAc,EAAE,WAAW,uBAAuB,CAAC,SAAS,OAAO;AACnE,iBAAc,gBAAgB;IAC9B,CACH;GACD,CAAC,QAAQ,EAAE,WAAW;AAGxB,qBAAoB,cAAc,OAAO,cAAc,+BAA+B;;;;;;;AAQxF,IAAM,qCAA2C;AAC/C,GAAE,qBAAqB,iBAAiB,UAAU,cAA2B;AAC3E,YAAU,gBAAgB;AAE1B,SAAO,SAAS;GAAE,UAAU;GAAU,KAAK;GAAG,CAAC;AAC/C,IAAE,mBAAmB,MAAM,EAAE,eAAe,MAAM,CAAC;GACnD;;AAGJ,SAAS,iBAAiB,0BAAgC;AACxD,+BAA8B;AAC9B,+BAA8B;EAC9B"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js new file mode 100644 index 00000000..8fa3cda8 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js @@ -0,0 +1,23 @@ +import "./journalisation.CEgm28xa.js"; +import "./exports.CurVqjr0.js"; +import { Kt as DOM_ENTREE_MENU_CATEGORIES_PRODUITS, a as mustGetEleInDocument, dn as Ra, en as DOM_MENU_CATEGORIES_PRODUITS, s as mustGetElesInDocument } from "./dom.emspS_OW.js"; +import { t as M } from "./dist.CzYTlmnN.js"; + +//#region web/app/themes/haiku-atelier-2024/src/scripts/scripts-menu-categories.ts +document.addEventListener("DOMContentLoaded", () => { + const MENU_CATEGORIES_PRODUITS = mustGetEleInDocument(DOM_MENU_CATEGORIES_PRODUITS); + const ENTREES_MENU_CATEGORIES_PRODUITS = mustGetElesInDocument(DOM_ENTREE_MENU_CATEGORIES_PRODUITS); + Ra.forEachWithIndex([ENTREES_MENU_CATEGORIES_PRODUITS.at(0), ENTREES_MENU_CATEGORIES_PRODUITS.at(-1)], (index, entreeMenu) => { + if (!entreeMenu) return; + new IntersectionObserver(Ra.forEach((entree) => { + if (entree.boundingClientRect.top <= 0) return; + M([entree.isIntersecting, index]).with([true, 0], () => MENU_CATEGORIES_PRODUITS.removeAttribute("data-entrees-presentes-debut")).with([true, 1], () => MENU_CATEGORIES_PRODUITS.removeAttribute("data-entrees-presentes-fin")).with([false, 0], () => MENU_CATEGORIES_PRODUITS.setAttribute("data-entrees-presentes-debut", "")).with([false, 1], () => MENU_CATEGORIES_PRODUITS.setAttribute("data-entrees-presentes-fin", "")).run(); + }), { + root: null, + threshold: .9 + }).observe(entreeMenu); + }); +}); + +//#endregion +//# sourceMappingURL=scripts-menu-categories.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js.map b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js.map new file mode 100644 index 00000000..f62c4d12 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-categories.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scripts-menu-categories.js","names":["MENU_CATEGORIES_PRODUITS: HTMLElement","ENTREES_MENU_CATEGORIES_PRODUITS: Array"],"sources":["../../src/scripts/scripts-menu-categories.ts"],"sourcesContent":["/** Scripts pour le Menu des Catégories de Produits */\n\nimport { A } from \"@mobily/ts-belt\";\nimport { match } from \"ts-pattern\";\n\nimport { DOM_ENTREE_MENU_CATEGORIES_PRODUITS, DOM_MENU_CATEGORIES_PRODUITS } from \"./constantes/dom.ts\";\nimport { mustGetEleInDocument, mustGetElesInDocument } from \"./lib/dom.ts\";\n\ndocument.addEventListener(\"DOMContentLoaded\", (): void => {\n const MENU_CATEGORIES_PRODUITS: HTMLElement = mustGetEleInDocument(DOM_MENU_CATEGORIES_PRODUITS);\n const ENTREES_MENU_CATEGORIES_PRODUITS: Array = mustGetElesInDocument(\n DOM_ENTREE_MENU_CATEGORIES_PRODUITS,\n );\n\n A.forEachWithIndex(\n [ENTREES_MENU_CATEGORIES_PRODUITS.at(0), ENTREES_MENU_CATEGORIES_PRODUITS.at(-1)],\n (index, entreeMenu): void => {\n if (!entreeMenu) return;\n\n new IntersectionObserver(\n A.forEach(entree => {\n // Ne déclenche rien si le scroll n'est pas horizontal\n if (entree.boundingClientRect.top <= 0) return;\n match([entree.isIntersecting, index])\n .with([true, 0], () => MENU_CATEGORIES_PRODUITS.removeAttribute(\"data-entrees-presentes-debut\"))\n .with([true, 1], () => MENU_CATEGORIES_PRODUITS.removeAttribute(\"data-entrees-presentes-fin\"))\n .with([false, 0], () => MENU_CATEGORIES_PRODUITS.setAttribute(\"data-entrees-presentes-debut\", \"\"))\n .with([false, 1], () => MENU_CATEGORIES_PRODUITS.setAttribute(\"data-entrees-presentes-fin\", \"\"))\n .run();\n }),\n { root: null, threshold: 0.9 },\n ).observe(entreeMenu);\n },\n );\n});\n"],"mappings":";;;;;;AAQA,SAAS,iBAAiB,0BAAgC;CACxD,MAAMA,2BAAwC,qBAAqB,6BAA6B;CAChG,MAAMC,mCAA6D,sBACjE,oCACD;AAED,IAAE,iBACA,CAAC,iCAAiC,GAAG,EAAE,EAAE,iCAAiC,GAAG,GAAG,CAAC,GAChF,OAAO,eAAqB;AAC3B,MAAI,CAAC,WAAY;AAEjB,MAAI,qBACF,GAAE,SAAQ,WAAU;AAElB,OAAI,OAAO,mBAAmB,OAAO,EAAG;AACxC,KAAM,CAAC,OAAO,gBAAgB,MAAM,CAAC,CAClC,KAAK,CAAC,MAAM,EAAE,QAAQ,yBAAyB,gBAAgB,+BAA+B,CAAC,CAC/F,KAAK,CAAC,MAAM,EAAE,QAAQ,yBAAyB,gBAAgB,6BAA6B,CAAC,CAC7F,KAAK,CAAC,OAAO,EAAE,QAAQ,yBAAyB,aAAa,gCAAgC,GAAG,CAAC,CACjG,KAAK,CAAC,OAAO,EAAE,QAAQ,yBAAyB,aAAa,8BAA8B,GAAG,CAAC,CAC/F,KAAK;IACR,EACF;GAAE,MAAM;GAAM,WAAW;GAAK,CAC/B,CAAC,QAAQ,WAAW;GAExB;EACD"} \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js new file mode 100644 index 00000000..3d1b3a38 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js @@ -0,0 +1,325 @@ +import { r as _defineProperty } from "./journalisation.CEgm28xa.js"; +import { dt as pipe } from "./exports.CurVqjr0.js"; +import { _t as ATTRIBUT_MENU_MOBILE_ACTIVE, a as mustGetEleInDocument, dn as Ra, kt as DOM_BOUTON_MENU_MOBILE, tn as DOM_MENU_MOBILE } from "./dom.emspS_OW.js"; +import "./belt_Option-91f3b350.CMbgtZ-W.js"; +import { t as P } from "./index-c1cc4c86.D2nZEikK.js"; + +//#region node_modules/a11y-dialog/dist/a11y-dialog.esm.js +var not = { + inert: ":not([inert]):not([inert] *)", + negTabIndex: ":not([tabindex^=\"-\"])", + disabled: ":not(:disabled)" +}; +var focusableSelectors = [ + `a[href]${not.inert}${not.negTabIndex}`, + `area[href]${not.inert}${not.negTabIndex}`, + `input:not([type="hidden"]):not([type="radio"])${not.inert}${not.negTabIndex}${not.disabled}`, + `input[type="radio"]${not.inert}${not.negTabIndex}${not.disabled}`, + `select${not.inert}${not.negTabIndex}${not.disabled}`, + `textarea${not.inert}${not.negTabIndex}${not.disabled}`, + `button${not.inert}${not.negTabIndex}${not.disabled}`, + `details${not.inert} > summary:first-of-type${not.negTabIndex}`, + `iframe${not.inert}${not.negTabIndex}`, + `audio[controls]${not.inert}${not.negTabIndex}`, + `video[controls]${not.inert}${not.negTabIndex}`, + `[contenteditable]${not.inert}${not.negTabIndex}`, + `[tabindex]${not.inert}${not.negTabIndex}` +]; +/** +* Set the focus to the first element with `autofocus` with the element or the +* element itself. +*/ +function focus(el) { + (el.querySelector("[autofocus]") || el).focus(); +} +/** +* Get the first and last focusable elements within a given element. +*/ +function getFocusableEdges(el) { + const firstEl = findFocusableEl(el, true); + return [firstEl, firstEl ? findFocusableEl(el, false) || firstEl : null]; +} +/** +* Find the first focusable element inside the given element if `forward` is +* truthy or the last focusable element otherwise. +*/ +function findFocusableEl(el, forward) { + if (forward && isFocusable(el)) return el; + if (canHaveFocusableChildren(el)) if (el.shadowRoot) { + let next = getNextChildEl(el.shadowRoot, forward); + while (next) { + const focusableEl = findFocusableEl(next, forward); + if (focusableEl) return focusableEl; + next = getNextSiblingEl(next, forward); + } + } else if (el.localName === "slot") { + const assignedElements = el.assignedElements({ flatten: true }); + if (!forward) assignedElements.reverse(); + for (const assignedElement of assignedElements) { + const focusableEl = findFocusableEl(assignedElement, forward); + if (focusableEl) return focusableEl; + } + } else { + let next = getNextChildEl(el, forward); + while (next) { + const focusableEl = findFocusableEl(next, forward); + if (focusableEl) return focusableEl; + next = getNextSiblingEl(next, forward); + } + } + if (!forward && isFocusable(el)) return el; + return null; +} +function getNextChildEl(el, forward) { + return forward ? el.firstElementChild : el.lastElementChild; +} +function getNextSiblingEl(el, forward) { + return forward ? el.nextElementSibling : el.previousElementSibling; +} +/** +* Determine if an element is hidden from the user. +*/ +var isHidden = (el) => { + if (el.matches("details:not([open]) *") && !el.matches("details>summary:first-of-type")) return true; + return !(el.offsetWidth || el.offsetHeight || el.getClientRects().length); +}; +/** +* Determine if an element is focusable and has user-visible painted dimensions. +*/ +var isFocusable = (el) => { + if (el.shadowRoot?.delegatesFocus) return false; + return el.matches(focusableSelectors.join(",")) && !isHidden(el); +}; +/** +* Determine if an element can have focusable children. Useful for bailing out +* early when walking the DOM tree. +* @example +* This div is inert, so none of its children can be focused, even though they +* meet our criteria for what is focusable. Once we check the div, we can skip +* the rest of the subtree. +* ```html +* +* ``` +*/ +function canHaveFocusableChildren(el) { + if (el.shadowRoot && el.getAttribute("tabindex") === "-1") return false; + return !el.matches(":disabled,[hidden],[inert]"); +} +/** +* Get the active element, accounting for Shadow DOM subtrees. +* @author Cory LaViska +* @see: https://www.abeautifulsite.net/posts/finding-the-active-element-in-a-shadow-root/ +*/ +function getActiveEl(root = document) { + const activeEl = root.activeElement; + if (!activeEl) return null; + if (activeEl.shadowRoot) return getActiveEl(activeEl.shadowRoot) || document.activeElement; + return activeEl; +} +/** +* Trap the focus inside the given element +*/ +function trapTabKey(el, event) { + const [firstFocusableEl, lastFocusableEl] = getFocusableEdges(el); + if (!firstFocusableEl) return event.preventDefault(); + const activeEl = getActiveEl(); + if (event.shiftKey && activeEl === firstFocusableEl) { + lastFocusableEl.focus(); + event.preventDefault(); + } else if (!event.shiftKey && activeEl === lastFocusableEl) { + firstFocusableEl.focus(); + event.preventDefault(); + } +} +/** +* Find the closest element to the given element matching the given selector, +* accounting for Shadow DOM subtrees. +* @author Louis St-Amour +* @see: https://stackoverflow.com/a/56105394 +*/ +function closest(selector, base) { + function from(el) { + if (!el || el === document || el === window) return null; + const slot = findAssignedSlot(el); + if (slot) el = slot; + return el.closest(selector) || from(el.getRootNode().host); + } + return from(base); +} +function findAssignedSlot(node) { + return node.assignedSlot || (node.parentNode ? findAssignedSlot(node.parentNode) : null); +} +var SCOPE = "data-a11y-dialog"; +var A11yDialog = class { + constructor(element) { + _defineProperty(this, "$el", void 0); + _defineProperty(this, "id", void 0); + _defineProperty(this, "previouslyFocused", void 0); + _defineProperty(this, "shown", void 0); + this.$el = element; + this.id = this.$el.getAttribute(SCOPE) || this.$el.id; + this.previouslyFocused = null; + this.shown = false; + this.maintainFocus = this.maintainFocus.bind(this); + this.bindKeypress = this.bindKeypress.bind(this); + this.handleTriggerClicks = this.handleTriggerClicks.bind(this); + this.show = this.show.bind(this); + this.hide = this.hide.bind(this); + this.$el.setAttribute("aria-hidden", "true"); + this.$el.setAttribute("aria-modal", "true"); + this.$el.setAttribute("tabindex", "-1"); + if (!this.$el.hasAttribute("role")) this.$el.setAttribute("role", "dialog"); + document.addEventListener("click", this.handleTriggerClicks, true); + } + /** + * Destroy the current instance (after making sure the dialog has been hidden) + * and remove all associated listeners from dialog openers and closers + */ + destroy() { + if (this.fire("destroy").defaultPrevented) return this; + this.hide(); + document.removeEventListener("click", this.handleTriggerClicks, true); + this.$el.replaceWith(this.$el.cloneNode(true)); + return this; + } + /** + * Show the dialog element, trap the current focus within it, listen for some + * specific key presses and fire all registered callbacks for `show` event + */ + show(event) { + if (this.shown) return this; + if (this.fire("show", event).defaultPrevented) return this; + this.shown = true; + this.$el.removeAttribute("aria-hidden"); + this.previouslyFocused = getActiveEl(); + if (this.previouslyFocused?.tagName === "BODY" && event?.target) this.previouslyFocused = event.target; + if (event?.type === "focus") this.maintainFocus(); + else focus(this.$el); + document.body.addEventListener("focus", this.maintainFocus, true); + this.$el.addEventListener("keydown", this.bindKeypress, true); + return this; + } + /** + * Hide the dialog element, restore the focus to the previously active + * element, stop listening for some specific key presses and fire all + * registered callbacks for `hide` event + */ + hide(event) { + if (!this.shown) return this; + if (this.fire("hide", event).defaultPrevented) return this; + this.shown = false; + this.$el.setAttribute("aria-hidden", "true"); + document.body.removeEventListener("focus", this.maintainFocus, true); + this.$el.removeEventListener("keydown", this.bindKeypress, true); + this.previouslyFocused?.focus?.(); + return this; + } + /** + * Register a new callback for the given event type + */ + on(type, handler, options) { + this.$el.addEventListener(type, handler, options); + return this; + } + /** + * Unregister an existing callback for the given event type + */ + off(type, handler, options) { + this.$el.removeEventListener(type, handler, options); + return this; + } + /** + * Dispatch and return a custom event from the DOM element associated with + * this dialog; this allows authors to listen for and respond to the events + * in their own code + */ + fire(type, event) { + const customEvent = new CustomEvent(type, { + detail: event, + cancelable: true + }); + this.$el.dispatchEvent(customEvent); + return customEvent; + } + /** + * Add a delegated event listener for when elememts that open or close the + * dialog are clicked, and call `show` or `hide`, respectively + */ + handleTriggerClicks(event) { + const target = event.composedPath()[0]; + const opener = closest(`[${SCOPE}-show="${this.id}"]`, target); + const explicitCloser = closest(`[${SCOPE}-hide="${this.id}"]`, target); + const implicitCloser = closest(`[${SCOPE}-hide]`, target) && closest("[aria-modal=\"true\"]", target) === this.$el; + if (opener) this.show(event); + if (explicitCloser || implicitCloser) this.hide(event); + } + /** + * Private event handler used when listening to some specific key presses + * (namely ESC and TAB) + */ + bindKeypress(event) { + if (closest("[aria-modal=\"true\"]", getActiveEl()) !== this.$el) return; + let hasOpenPopover = false; + try { + hasOpenPopover = !!this.$el.querySelector("[popover]:not([popover=\"manual\"]):popover-open"); + } catch {} + if (event.key === "Escape" && this.$el.getAttribute("role") !== "alertdialog" && !hasOpenPopover) { + event.preventDefault(); + this.hide(event); + } + if (event.key === "Tab") trapTabKey(this.$el, event); + } + /** + * If the dialog is shown and the focus is not within a dialog element (either + * this one or another one in case of nested dialogs) or an element with the + * ignore attribute, move it back to the dialog container + * See: https://github.com/KittyGiraudel/a11y-dialog/issues/177 + */ + maintainFocus() { + const target = getActiveEl(); + if (!closest(`[aria-modal="true"], [${SCOPE}-ignore-focus-trap]`, target)) focus(this.$el); + } +}; +function instantiateDialogs() { + for (const el of document.querySelectorAll("[data-a11y-dialog]")) new A11yDialog(el); +} +if (typeof document !== "undefined") if (document.readyState === "loading") document.addEventListener("DOMContentLoaded", instantiateDialogs); +else instantiateDialogs(); + +//#endregion +//#region web/app/themes/haiku-atelier-2024/src/scripts/scripts-menu-mobile.ts +var E = { + BOUTON_MENU_MOBILE: mustGetEleInDocument(DOM_BOUTON_MENU_MOBILE), + CORPS_HTML: mustGetEleInDocument("body"), + MENU_MOBILE: mustGetEleInDocument(DOM_MENU_MOBILE) +}; +var initialiseBoutonMenuMobile = () => { + const menuMobile = new A11yDialog(E.MENU_MOBILE); + new ResizeObserver((entrees) => pipe(Ra.head(entrees), P.filter((entree) => entree.borderBoxSize[0].inlineSize > 1e3), P.tap((_) => menuMobile.hide()))).observe(E.CORPS_HTML); + E.BOUTON_MENU_MOBILE.addEventListener("click", () => { + if (window.innerWidth > 1e3) { + window.location.href = "/"; + return; + } + if (E.BOUTON_MENU_MOBILE.hasAttribute("data-menu-mobile-active")) { + menuMobile.hide(); + return; + } + menuMobile.show(); + }); + menuMobile.on("show", () => { + E.BOUTON_MENU_MOBILE.setAttribute(ATTRIBUT_MENU_MOBILE_ACTIVE, ""); + }); + menuMobile.on("hide", () => { + E.BOUTON_MENU_MOBILE.removeAttribute(ATTRIBUT_MENU_MOBILE_ACTIVE); + }); +}; +document.addEventListener("DOMContentLoaded", () => { + initialiseBoutonMenuMobile(); +}); + +//#endregion +//# sourceMappingURL=scripts-menu-mobile.js.map \ No newline at end of file diff --git a/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js.map b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js.map new file mode 100644 index 00000000..2b68a9c5 --- /dev/null +++ b/web/app/themes/haiku-atelier-2024/assets/js/scripts-menu-mobile.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scripts-menu-mobile.js","names":[],"sources":["../../../../../../node_modules/a11y-dialog/dist/a11y-dialog.esm.js","../../src/scripts/scripts-menu-mobile.ts"],"sourcesContent":["const not = {\n inert: ':not([inert]):not([inert] *)',\n negTabIndex: ':not([tabindex^=\"-\"])',\n disabled: ':not(:disabled)',\n};\n\nvar focusableSelectors = [\n `a[href]${not.inert}${not.negTabIndex}`,\n `area[href]${not.inert}${not.negTabIndex}`,\n `input:not([type=\"hidden\"]):not([type=\"radio\"])${not.inert}${not.negTabIndex}${not.disabled}`,\n `input[type=\"radio\"]${not.inert}${not.negTabIndex}${not.disabled}`,\n `select${not.inert}${not.negTabIndex}${not.disabled}`,\n `textarea${not.inert}${not.negTabIndex}${not.disabled}`,\n `button${not.inert}${not.negTabIndex}${not.disabled}`,\n `details${not.inert} > summary:first-of-type${not.negTabIndex}`,\n // Discard until Firefox supports `:has()`\n // See: https://github.com/KittyGiraudel/focusable-selectors/issues/12\n // `details:not(:has(> summary))${not.inert}${not.negTabIndex}`,\n `iframe${not.inert}${not.negTabIndex}`,\n `audio[controls]${not.inert}${not.negTabIndex}`,\n `video[controls]${not.inert}${not.negTabIndex}`,\n `[contenteditable]${not.inert}${not.negTabIndex}`,\n `[tabindex]${not.inert}${not.negTabIndex}`,\n];\n\n/**\n * Set the focus to the first element with `autofocus` with the element or the\n * element itself.\n */\nfunction focus(el) {\n (el.querySelector('[autofocus]') || el).focus();\n}\n/**\n * Get the first and last focusable elements within a given element.\n */\nfunction getFocusableEdges(el) {\n // Check for a focusable element within the subtree of the given element.\n const firstEl = findFocusableEl(el, true);\n // Only if we find the first element do we need to look for the last one. If\n // there’s no last element, we set `lastEl` as a reference to `firstEl` so\n // that the returned array is still always of length 2.\n const lastEl = firstEl ? findFocusableEl(el, false) || firstEl : null;\n return [firstEl, lastEl];\n}\n/**\n * Find the first focusable element inside the given element if `forward` is\n * truthy or the last focusable element otherwise.\n */\nfunction findFocusableEl(el, forward) {\n // If we’re walking forward, check if this element is focusable, and return it\n // immediately if it is.\n if (forward && isFocusable(el))\n return el;\n // We should only search the subtree of this element if it can have focusable\n // children.\n if (canHaveFocusableChildren(el)) {\n // Start walking the DOM tree, looking for focusable elements.\n // Case 1: If this element has a shadow root, search it recursively.\n if (el.shadowRoot) {\n // Descend into this subtree.\n let next = getNextChildEl(el.shadowRoot, forward);\n // Traverse the siblings, searching the subtree of each one for focusable\n // elements.\n while (next) {\n const focusableEl = findFocusableEl(next, forward);\n if (focusableEl)\n return focusableEl;\n next = getNextSiblingEl(next, forward);\n }\n }\n // Case 2: If this element is a slot for a Custom Element, search its\n // assigned elements recursively.\n else if (el.localName === 'slot') {\n const assignedElements = el.assignedElements({\n flatten: true,\n });\n if (!forward)\n assignedElements.reverse();\n for (const assignedElement of assignedElements) {\n const focusableEl = findFocusableEl(assignedElement, forward);\n if (focusableEl)\n return focusableEl;\n }\n }\n // Case 3: this is a regular Light DOM element. Search its subtree.\n else {\n // Descend into this subtree.\n let next = getNextChildEl(el, forward);\n // Traverse siblings, searching the subtree of each one\n // for focusable elements.\n while (next) {\n const focusableEl = findFocusableEl(next, forward);\n if (focusableEl)\n return focusableEl;\n next = getNextSiblingEl(next, forward);\n }\n }\n }\n // If we’re walking backward, we want to check the element’s entire subtree\n // before checking the element itself. If this element is focusable, return\n // it.\n if (!forward && isFocusable(el))\n return el;\n return null;\n}\nfunction getNextChildEl(el, forward) {\n return forward ? el.firstElementChild : el.lastElementChild;\n}\nfunction getNextSiblingEl(el, forward) {\n return forward ? el.nextElementSibling : el.previousElementSibling;\n}\n/**\n * Determine if an element is hidden from the user.\n */\nconst isHidden = (el) => {\n // Browsers hide all non- descendants of closed
elements\n // from user interaction, but those non- elements may still match our\n // focusable-selectors and may still have dimensions, so we need a special\n // case to ignore them.\n if (el.matches('details:not([open]) *') &&\n !el.matches('details>summary:first-of-type'))\n return true;\n // If this element has no painted dimensions, it's hidden.\n return !(el.offsetWidth || el.offsetHeight || el.getClientRects().length);\n};\n/**\n * Determine if an element is focusable and has user-visible painted dimensions.\n */\nconst isFocusable = (el) => {\n // A shadow host that delegates focus will never directly receive focus,\n // even with `tabindex=0`. Consider our custom element, which\n // delegates focus to its shadow button:\n //\n // \n // #shadow-root\n // \n // \n //\n // The browser acts as as if there is only one focusable element – the shadow\n // button. Our library should behave the same way.\n if (el.shadowRoot?.delegatesFocus)\n return false;\n return el.matches(focusableSelectors.join(',')) && !isHidden(el);\n};\n/**\n * Determine if an element can have focusable children. Useful for bailing out\n * early when walking the DOM tree.\n * @example\n * This div is inert, so none of its children can be focused, even though they\n * meet our criteria for what is focusable. Once we check the div, we can skip\n * the rest of the subtree.\n * ```html\n *
\n * \n * Link\n *
\n * ```\n */\nfunction canHaveFocusableChildren(el) {\n // The browser will never send focus into a Shadow DOM if the host element\n // has a negative tabindex. This applies to both slotted Light DOM Shadow DOM\n // children\n if (el.shadowRoot && el.getAttribute('tabindex') === '-1')\n return false;\n // Elemments matching this selector are either hidden entirely from the user,\n // or are visible but unavailable for interaction. Their descentants can never\n // receive focus.\n return !el.matches(':disabled,[hidden],[inert]');\n}\n/**\n * Get the active element, accounting for Shadow DOM subtrees.\n * @author Cory LaViska\n * @see: https://www.abeautifulsite.net/posts/finding-the-active-element-in-a-shadow-root/\n */\nfunction getActiveEl(root = document) {\n const activeEl = root.activeElement;\n if (!activeEl)\n return null;\n // If there’s a shadow root, recursively find the active element within it.\n // If the recursive call returns null, return the active element\n // of the top-level Document.\n if (activeEl.shadowRoot)\n return getActiveEl(activeEl.shadowRoot) || document.activeElement;\n // If not, we can just return the active element\n return activeEl;\n}\n/**\n * Trap the focus inside the given element\n */\nfunction trapTabKey(el, event) {\n const [firstFocusableEl, lastFocusableEl] = getFocusableEdges(el);\n // If there are no focusable children in the dialog, prevent the user from\n // tabbing out of it\n if (!firstFocusableEl)\n return event.preventDefault();\n const activeEl = getActiveEl();\n // If the SHIFT key is pressed while tabbing (moving backwards) and the\n // currently focused item is the first one, move the focus to the last\n // focusable item from the dialog element\n if (event.shiftKey && activeEl === firstFocusableEl) {\n // @ts-ignore: we know that `lastFocusableEl` is not null here\n lastFocusableEl.focus();\n event.preventDefault();\n }\n // If the SHIFT key is not pressed (moving forwards) and the currently focused\n // item is the last one, move the focus to the first focusable item from the\n // dialog element\n else if (!event.shiftKey && activeEl === lastFocusableEl) {\n firstFocusableEl.focus();\n event.preventDefault();\n }\n}\n/**\n * Find the closest element to the given element matching the given selector,\n * accounting for Shadow DOM subtrees.\n * @author Louis St-Amour\n * @see: https://stackoverflow.com/a/56105394\n */\nfunction closest(selector, base) {\n function from(el) {\n if (!el || el === document || el === window)\n return null;\n // Reading the `assignedSlot` property from the element (as suggested by the\n // aforementioned StackOverflow answer) is not enough, because it does not\n // take into consideration elements nested deeply within a . For these\n // elements, the `assignedSlot` property is `null` as it is only specified\n // for top-level elements within a . To still find the closest ,\n // we walk up the tree looking for the `assignedSlot` property.\n const slot = findAssignedSlot(el);\n if (slot)\n el = slot;\n return (el.closest(selector) ||\n from(el.getRootNode().host));\n }\n return from(base);\n}\nfunction findAssignedSlot(node) {\n return (node.assignedSlot ||\n (node.parentNode ? findAssignedSlot(node.parentNode) : null));\n}\n\nconst SCOPE = 'data-a11y-dialog';\nclass A11yDialog {\n $el;\n id;\n previouslyFocused;\n shown;\n constructor(element) {\n this.$el = element;\n this.id = this.$el.getAttribute(SCOPE) || this.$el.id;\n this.previouslyFocused = null;\n this.shown = false;\n this.maintainFocus = this.maintainFocus.bind(this);\n this.bindKeypress = this.bindKeypress.bind(this);\n this.handleTriggerClicks = this.handleTriggerClicks.bind(this);\n this.show = this.show.bind(this);\n this.hide = this.hide.bind(this);\n this.$el.setAttribute('aria-hidden', 'true');\n this.$el.setAttribute('aria-modal', 'true');\n this.$el.setAttribute('tabindex', '-1');\n if (!this.$el.hasAttribute('role')) {\n this.$el.setAttribute('role', 'dialog');\n }\n document.addEventListener('click', this.handleTriggerClicks, true);\n }\n /**\n * Destroy the current instance (after making sure the dialog has been hidden)\n * and remove all associated listeners from dialog openers and closers\n */\n destroy() {\n // Dispatch a `destroy` event\n const destroyEvent = this.fire('destroy');\n // If the event was prevented, do not continue with the normal behavior\n if (destroyEvent.defaultPrevented)\n return this;\n // Hide the dialog to avoid destroying an open instance\n this.hide();\n // Remove the click event delegates for our openers and closers\n document.removeEventListener('click', this.handleTriggerClicks, true);\n // Clone and replace the dialog element to prevent memory leaks caused by\n // event listeners that the author might not have cleaned up.\n this.$el.replaceWith(this.$el.cloneNode(true));\n return this;\n }\n /**\n * Show the dialog element, trap the current focus within it, listen for some\n * specific key presses and fire all registered callbacks for `show` event\n */\n show(event) {\n // If the dialog is already open, abort\n if (this.shown)\n return this;\n // Dispatch a `show` event\n const showEvent = this.fire('show', event);\n // If the event was prevented, do not continue with the normal behavior\n if (showEvent.defaultPrevented)\n return this;\n // Keep a reference to the currently focused element to be able to restore\n // it later\n this.shown = true;\n this.$el.removeAttribute('aria-hidden');\n this.previouslyFocused = getActiveEl();\n // Due to a long lasting bug in Safari, clicking an interactive element\n // (like a