From 0f277bcfa58b11fce73ae3065743ddb67eefadab Mon Sep 17 00:00:00 2001 From: Nuckyz <61953774+Nuckyz@users.noreply.github.com> Date: Fri, 30 Aug 2024 05:53:21 -0300 Subject: [PATCH] Add ts-pattern as common --- package.json | 1 + pnpm-lock.yaml | 8 ++++++++ src/webpack/common/utils.ts | 5 +++++ 3 files changed, 14 insertions(+) diff --git a/package.json b/package.json index 65d97f2e0..0fdda2659 100644 --- a/package.json +++ b/package.json @@ -70,6 +70,7 @@ "stylelint": "^16.8.1", "stylelint-config-standard": "^36.0.1", "ts-patch": "^3.2.1", + "ts-pattern": "^5.3.1", "tsx": "^4.16.5", "type-fest": "^4.23.0", "typescript": "^5.5.4", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 9567475fb..eaa6b537c 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -116,6 +116,9 @@ importers: ts-patch: specifier: ^3.2.1 version: 3.2.1 + ts-pattern: + specifier: ^5.3.1 + version: 5.3.1 tsx: specifier: ^4.16.5 version: 4.16.5 @@ -2524,6 +2527,9 @@ packages: resolution: {integrity: sha512-hlR43v+GUIUy8/ZGFP1DquEqPh7PFKQdDMTAmYt671kCCA6AkDQMoeFaFmZ7ObPLYOmpMgyKUqL1C+coFMf30w==} hasBin: true + ts-pattern@5.3.1: + resolution: {integrity: sha512-1RUMKa8jYQdNfmnK4jyzBK3/PS/tnjcZ1CW0v1vWDeYe5RBklc/nquw03MEoB66hVBm4BnlCfmOqDVxHyT1DpA==} + tsconfig-paths@3.15.0: resolution: {integrity: sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==} @@ -5158,6 +5164,8 @@ snapshots: semver: 7.6.3 strip-ansi: 6.0.1 + ts-pattern@5.3.1: {} + tsconfig-paths@3.15.0: dependencies: '@types/json5': 0.0.29 diff --git a/src/webpack/common/utils.ts b/src/webpack/common/utils.ts index 5eb81ffcc..223e09489 100644 --- a/src/webpack/common/utils.ts +++ b/src/webpack/common/utils.ts @@ -46,6 +46,11 @@ export const moment = findByProps("parseTwoDigitYear"); export const hljs = findByProps("highlight", "registerLanguage"); +export const { match, P }: Pick = mapMangledModule("@ts-pattern/matcher", { + match: filters.byCode("return new"), + P: filters.byProps("when") +}); + export const lodash = findByProps("debounce", "cloneDeep"); export const i18n = find(m => m.Messages?.["en-US"]);