From 0f5a39e317d2f7cf4b7b82182d4d3f4b9179f91b Mon Sep 17 00:00:00 2001 From: Martin Schoeler Date: Thu, 29 Aug 2024 18:08:48 -0300 Subject: [PATCH 1/4] refactor: Realtime Monitoring Counters to TS (#33182) --- .../counter/CounterContainer.stories.tsx | 10 ++++----- ...unterContainer.js => CounterContainer.tsx} | 22 ++++++++++++++++--- 2 files changed, 24 insertions(+), 8 deletions(-) rename apps/meteor/client/views/omnichannel/realTimeMonitoring/counter/{CounterContainer.js => CounterContainer.tsx} (59%) diff --git a/apps/meteor/client/views/omnichannel/realTimeMonitoring/counter/CounterContainer.stories.tsx b/apps/meteor/client/views/omnichannel/realTimeMonitoring/counter/CounterContainer.stories.tsx index d3a43adf701d1..c3e4d0aeb5355 100644 --- a/apps/meteor/client/views/omnichannel/realTimeMonitoring/counter/CounterContainer.stories.tsx +++ b/apps/meteor/client/views/omnichannel/realTimeMonitoring/counter/CounterContainer.stories.tsx @@ -12,10 +12,10 @@ export const Default: ComponentStory = (args) => { +export type DataType = { + title: string; + value: number | string; +}[]; + +type Totalizers = { + totalizers: DataType; +}; + +type CounterContainerProps = { + data?: Totalizers; + state: AsyncStatePhase; + initialData: DataType; +}; + +const CounterContainer = ({ data, state, initialData, ...props }: CounterContainerProps) => { const t = useTranslation(); - const [displayData, setDisplayData] = useState(initialData); + const [displayData, setDisplayData] = useState(initialData); const { totalizers } = data || { totalizers: initialData }; @@ -22,7 +38,7 @@ const CounterContainer = ({ data, state, initialData, ...props }) => { return ( {displayData.map(({ title, value }, i) => ( - } count={value} /> + } count={value} /> ))} ); From bb94c9c67a06a13461374cce1f27e1f7a28e64f2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BAlia=20Jaeger=20Foresti?= <60678893+juliajforesti@users.noreply.github.com> Date: Fri, 30 Aug 2024 00:55:30 -0300 Subject: [PATCH 2/4] feat: add `sidepanelNavigation` to Feature preview list (#33156) --- .changeset/brown-singers-appear.md | 7 ++++++ .../AccountFeaturePreviewPage.tsx | 25 +++++++++++++++++-- packages/i18n/src/locales/en.i18n.json | 6 ++++- .../src/hooks/useFeaturePreviewList.ts | 20 ++++++++++++++- 4 files changed, 54 insertions(+), 4 deletions(-) create mode 100644 .changeset/brown-singers-appear.md diff --git a/.changeset/brown-singers-appear.md b/.changeset/brown-singers-appear.md new file mode 100644 index 0000000000000..8a9a69f225ac6 --- /dev/null +++ b/.changeset/brown-singers-appear.md @@ -0,0 +1,7 @@ +--- +'@rocket.chat/ui-client': minor +'@rocket.chat/i18n': minor +'@rocket.chat/meteor': minor +--- + +added `sidepanelNavigation` to feature preview list diff --git a/apps/meteor/client/views/account/featurePreview/AccountFeaturePreviewPage.tsx b/apps/meteor/client/views/account/featurePreview/AccountFeaturePreviewPage.tsx index c8cd7138e5a6f..dd9ab6a90959a 100644 --- a/apps/meteor/client/views/account/featurePreview/AccountFeaturePreviewPage.tsx +++ b/apps/meteor/client/views/account/featurePreview/AccountFeaturePreviewPage.tsx @@ -24,6 +24,21 @@ import { useForm } from 'react-hook-form'; import { Page, PageHeader, PageScrollableContentWithShadow, PageFooter } from '../../../components/Page'; +const handleEnableQuery = (features: FeaturePreviewProps[]) => { + return features.map((item) => { + if (item.enableQuery) { + const expected = item.enableQuery.value; + const received = features.find((el) => el.name === item.enableQuery?.name)?.value; + if (expected !== received) { + item.disabled = true; + item.value = false; + } else { + item.disabled = false; + } + } + return item; + }); +}; const AccountFeaturePreviewPage = () => { const t = useTranslation(); const dispatchToastMessage = useToastMessageDispatch(); @@ -71,7 +86,7 @@ const AccountFeaturePreviewPage = () => { }; const grouppedFeaturesPreview = Object.entries( - featuresPreview.reduce((result, currentValue) => { + handleEnableQuery(featuresPreview).reduce((result, currentValue) => { (result[currentValue.group] = result[currentValue.group] || []).push(currentValue); return result; }, {} as Record), @@ -108,7 +123,13 @@ const AccountFeaturePreviewPage = () => { {t(feature.i18n)} - + {feature.description && {t(feature.description)}} diff --git a/packages/i18n/src/locales/en.i18n.json b/packages/i18n/src/locales/en.i18n.json index 159c1641e05e7..b28b1fc2bfde1 100644 --- a/packages/i18n/src/locales/en.i18n.json +++ b/packages/i18n/src/locales/en.i18n.json @@ -6533,5 +6533,9 @@ "Sidebar_Sections_Order_Description": "Select the categories in your preferred order", "Incoming_Calls": "Incoming calls", "Advanced_settings": "Advanced settings", - "Security_and_permissions": "Security and permissions" + "Security_and_permissions": "Security and permissions", + "Sidepanel_navigation": "Sidepanel navigation for teams", + "Sidepanel_navigation_description": "Option to open a sidepanel with channels and/or discussions associated with the team. This allows team owners to customize communication methods to best meet their team’s needs. This feature is only available when Enhanced navigation experience is enabled.", + "Show_channels_description": "Show team channels in second sidebar", + "Show_discussions_description": "Show team discussions in second sidebar" } diff --git a/packages/ui-client/src/hooks/useFeaturePreviewList.ts b/packages/ui-client/src/hooks/useFeaturePreviewList.ts index 4e79eebbd13a4..172045197f8cf 100644 --- a/packages/ui-client/src/hooks/useFeaturePreviewList.ts +++ b/packages/ui-client/src/hooks/useFeaturePreviewList.ts @@ -6,7 +6,8 @@ export type FeaturesAvailable = | 'navigationBar' | 'enable-timestamp-message-parser' | 'contextualbarResizable' - | 'newNavigation'; + | 'newNavigation' + | 'sidepanelNavigation'; export type FeaturePreviewProps = { name: FeaturesAvailable; @@ -16,6 +17,11 @@ export type FeaturePreviewProps = { imageUrl?: string; value: boolean; enabled: boolean; + disabled?: boolean; + enableQuery?: { + name: FeaturesAvailable; + value: boolean; + }; }; export const defaultFeaturesPreview: FeaturePreviewProps[] = [ @@ -60,6 +66,18 @@ export const defaultFeaturesPreview: FeaturePreviewProps[] = [ value: false, enabled: true, }, + { + name: 'sidepanelNavigation', + i18n: 'Sidepanel_navigation', + description: 'Sidepanel_navigation_description', + group: 'Navigation', + value: false, + enabled: false, + enableQuery: { + name: 'newNavigation', + value: true, + }, + }, ]; export const enabledDefaultFeatures = defaultFeaturesPreview.filter((feature) => feature.enabled); From 377b8bbd945c4d9e5e36952f9ee58eaa6515a3bc Mon Sep 17 00:00:00 2001 From: Tasso Evangelista Date: Mon, 2 Sep 2024 11:16:59 -0300 Subject: [PATCH 3/4] refactor: Upgrade to TypeScript 5.5 (#33187) --- ...patch => typia-npm-6.9.0-2fd4d85f25.patch} | 248 ++++++++++-------- apps/meteor/client/hooks/useEndpointAction.ts | 2 +- apps/meteor/client/hooks/useEndpointData.ts | 4 +- apps/meteor/client/lib/createRouteGroup.tsx | 14 +- apps/meteor/client/lib/getLocalePercentage.ts | 9 +- .../providers/CallProvider/CallProvider.tsx | 4 +- .../DeviceProvider/DeviceProvider.tsx | 4 +- .../lib/isSetSinkIdAvailable.tsx | 4 +- .../client/providers/TranslationProvider.tsx | 2 +- .../client/views/admin/viewLogs/ansispan.ts | 15 +- apps/meteor/ee/server/services/package.json | 2 +- apps/meteor/package.json | 4 +- .../server/services/federation/Federation.ts | 4 +- ee/apps/account-service/package.json | 2 +- ee/apps/authorization-service/package.json | 2 +- ee/apps/ddp-streamer/package.json | 2 +- ee/apps/omnichannel-transcript/package.json | 2 +- ee/apps/presence-service/package.json | 2 +- ee/apps/queue-worker/package.json | 2 +- ee/apps/stream-hub-service/package.json | 2 +- ee/packages/license/package.json | 2 +- ee/packages/omnichannel-services/package.json | 2 +- ee/packages/pdf-worker/package.json | 2 +- ee/packages/presence/package.json | 2 +- ee/packages/ui-theming/package.json | 2 +- package.json | 3 +- packages/account-utils/package.json | 2 +- packages/agenda/package.json | 2 +- packages/api-client/package.json | 2 +- packages/apps/package.json | 2 +- packages/base64/package.json | 2 +- packages/cas-validate/package.json | 2 +- packages/core-services/package.json | 2 +- packages/core-typings/package.json | 2 +- packages/cron/package.json | 2 +- packages/ddp-client/package.json | 2 +- packages/favicon/package.json | 2 +- packages/fuselage-ui-kit/package.json | 2 +- packages/gazzodown/package.json | 2 +- packages/i18n/package.json | 2 +- packages/instance-status/package.json | 2 +- packages/jest-presets/package.json | 2 +- packages/jwt/package.json | 2 +- packages/livechat/package.json | 2 +- packages/log-format/package.json | 2 +- packages/logger/package.json | 2 +- packages/message-parser/package.json | 2 +- packages/mock-providers/package.json | 2 +- packages/model-typings/package.json | 2 +- packages/models/package.json | 2 +- packages/node-poplib/package.json | 2 +- packages/password-policies/package.json | 2 +- packages/patch-injection/package.json | 2 +- packages/peggy-loader/package.json | 2 +- packages/random/package.json | 2 +- packages/release-action/package.json | 2 +- packages/release-changelog/package.json | 2 +- packages/rest-typings/package.json | 2 +- .../server-cloud-communication/package.json | 2 +- packages/server-fetch/package.json | 2 +- packages/sha256/package.json | 2 +- packages/tools/package.json | 2 +- packages/ui-avatar/package.json | 2 +- packages/ui-client/package.json | 2 +- packages/ui-composer/package.json | 2 +- packages/ui-contexts/package.json | 2 +- packages/ui-contexts/src/DeviceContext.ts | 6 +- packages/ui-contexts/src/hooks/useEndpoint.ts | 2 +- .../src/hooks/useSetOutputMediaDevice.ts | 10 +- packages/ui-contexts/src/index.ts | 2 +- packages/ui-kit/package.json | 6 +- packages/ui-video-conf/package.json | 2 +- packages/uikit-playground/package.json | 2 +- packages/web-ui-registration/package.json | 2 +- yarn.lock | 199 +++++++------- 75 files changed, 334 insertions(+), 320 deletions(-) rename .yarn/patches/{typia-npm-5.3.3-21d3e18463.patch => typia-npm-6.9.0-2fd4d85f25.patch} (64%) diff --git a/.yarn/patches/typia-npm-5.3.3-21d3e18463.patch b/.yarn/patches/typia-npm-6.9.0-2fd4d85f25.patch similarity index 64% rename from .yarn/patches/typia-npm-5.3.3-21d3e18463.patch rename to .yarn/patches/typia-npm-6.9.0-2fd4d85f25.patch index 1487a9f4712d0..22a02fa159578 100644 --- a/.yarn/patches/typia-npm-5.3.3-21d3e18463.patch +++ b/.yarn/patches/typia-npm-6.9.0-2fd4d85f25.patch @@ -1,22 +1,22 @@ diff --git a/lib/factories/internal/metadata/iterate_metadata_intersection.js b/lib/factories/internal/metadata/iterate_metadata_intersection.js -index 260670b8ea37b63dcacadeffa26450f81087c90e..f07b44b16099d896ab40c46f03df86ee2f2c1a90 100644 +index da05ef3ac6f397d68b8fa10285f62d1794c57579..0f2b9b26e01cebd0b9c04a2db8857f911cfbaf57 100644 --- a/lib/factories/internal/metadata/iterate_metadata_intersection.js +++ b/lib/factories/internal/metadata/iterate_metadata_intersection.js -@@ -247,7 +247,7 @@ var iterate_metadata_intersection = function (checker) { +@@ -181,7 +181,7 @@ var iterate_metadata_intersection = function (checker) { var tags = MetadataTypeTagFactory_1.MetadataTypeTagFactory.analyze(errors)(target)(objects.map(function (om) { return om.objects; }).flat(), explore); if (tags.length) if (target === "array") - meta.arrays.at(-1).tags.push(tags); + meta.arrays.slice(-1)[0].tags.push(tags); - else if (booleanLiteral === null) + else if (atomics.size) meta.atomics.find(function (a) { return a.type === target; }).tags.push(tags); - else { + else if (constants.length) { diff --git a/lib/programmers/CheckerProgrammer.js b/lib/programmers/CheckerProgrammer.js -index bbec09f22798d144b96f59bb946e7e32e3438c05..dc13cb47b72358b8e6165b768cff2360db2bd617 100644 +index 662e6ff51c91598229c88f691b7ce07200957167..4028a50cc92ee293e98b13822293d0fb35c64c1f 100644 --- a/lib/programmers/CheckerProgrammer.js +++ b/lib/programmers/CheckerProgrammer.js -@@ -458,8 +458,8 @@ var CheckerProgrammer; - ? "".concat(explore.postfix.slice(0, -1), "[").concat(index, "]\"") +@@ -529,8 +529,8 @@ var CheckerProgrammer; + ? "".concat((0, postfix_of_tuple_1.postfix_of_tuple)(explore.postfix), "[").concat(index, "]\"") : "\"[".concat(index, "]\"") })); }); - var rest = tuple.elements.length && tuple.elements.at(-1).rest !== null @@ -27,7 +27,7 @@ index bbec09f22798d144b96f59bb946e7e32e3438c05..dc13cb47b72358b8e6165b768cff2360 var arrayLength = typescript_1.default.factory.createPropertyAccessExpression(input, "length"); return config.combiner(explore)("and")(input, __spreadArray(__spreadArray(__spreadArray([], __read((rest === null diff --git a/lib/programmers/TypiaProgrammer.js b/lib/programmers/TypiaProgrammer.js -index c75ab1bc077b788e36c32834ea4916c22df34500..99452220e2dd090d4d562296e26fb266faa617f9 100644 +index db244cb5e40fd68e15b7a06936b0f92802e5e4c9..c2f64885f67cc543c62b0b09e141c88684f99253 100644 --- a/lib/programmers/TypiaProgrammer.js +++ b/lib/programmers/TypiaProgrammer.js @@ -165,7 +165,7 @@ var TypiaProgrammer; @@ -39,34 +39,53 @@ index c75ab1bc077b788e36c32834ea4916c22df34500..99452220e2dd090d4d562296e26fb266 })() : [0, 0], 2), line = _k[0], pos = _k[1]; console.error("".concat(file, ":").concat(line, ":").concat(pos, " - ").concat(category, " TS").concat(diag.code, ": ").concat(diag.messageText)); -diff --git a/lib/programmers/internal/application_tuple.js b/lib/programmers/internal/application_tuple.js -index 5c1853a3a1692f95fe702bdae9813e958f54ac4c..04ca996c2ffe72d1cd5969e45a38e91937b975b1 100644 ---- a/lib/programmers/internal/application_tuple.js -+++ b/lib/programmers/internal/application_tuple.js -@@ -22,15 +22,15 @@ var application_tuple = function (options) { - var schema = __assign(__assign({ type: "array", items: tuple.type.elements.map(function (meta, i) { - var _a; - return (0, application_schema_1.application_schema)(options)(false)(components)((_a = meta.rest) !== null && _a !== void 0 ? _a : meta)(__assign(__assign({}, attribute), { "x-typia-rest": i === tuple.type.elements.length - 1 && meta.rest !== null, "x-typia-required": meta.required, "x-typia-optional": meta.optional })); -- }) }, attribute), { minItems: !!((_a = tuple.type.elements.at(-1)) === null || _a === void 0 ? void 0 : _a.rest) -+ }) }, attribute), { minItems: !!((_a = tuple.type.elements.slice(-1)[0]) === null || _a === void 0 ? void 0 : _a.rest) - ? tuple.type.elements.length - 1 -- : tuple.type.elements.filter(function (x) { return !x.optional; }).length, maxItems: !!((_b = tuple.type.elements.at(-1)) === null || _b === void 0 ? void 0 : _b.rest) -+ : tuple.type.elements.filter(function (x) { return !x.optional; }).length, maxItems: !!((_b = tuple.type.elements.slice(-1)[0]) === null || _b === void 0 ? void 0 : _b.rest) - ? undefined - : tuple.type.elements.length }); - if (options.purpose === "ajv") - if (tuple.type.elements.length === 0) - return schema; -- else if (!((_c = tuple.type.elements.at(-1)) === null || _c === void 0 ? void 0 : _c.rest)) -+ else if (!((_c = tuple.type.elements.slice(-1)[0]) === null || _c === void 0 ? void 0 : _c.rest)) - return schema; - var wrapper = __assign(__assign({}, schema), { items: (0, application_schema_1.application_schema)(options)(false)(components)(tuple.type.elements.reduce(function (x, y) { var _a, _b; return Metadata_1.Metadata.merge((_a = x.rest) !== null && _a !== void 0 ? _a : x, (_b = y.rest) !== null && _b !== void 0 ? _b : y); }, Metadata_1.Metadata.initialize()))(tuple.type.recursive ? {} : attribute), "x-typia-tuple": schema, minItems: schema.minItems, maxItems: schema.maxItems }); - return wrapper; +diff --git a/lib/programmers/internal/application_v30_tuple.js b/lib/programmers/internal/application_v30_tuple.js +index 94e8827fd94df3792c1d7b2cdacac604175ba8ca..c9a3a1bcdd978b97a080ed2c467188d808d10c8f 100644 +--- a/lib/programmers/internal/application_v30_tuple.js ++++ b/lib/programmers/internal/application_v30_tuple.js +@@ -21,9 +21,9 @@ var application_v30_tuple = function (components) { + return function (tuple) { + return function (attribute) { + var _a, _b; +- return (__assign(__assign({}, attribute), { type: "array", items: (0, application_v30_schema_1.application_v30_schema)(false)(components)(tuple.type.recursive ? {} : attribute)(tuple.type.elements.reduce(function (x, y) { var _a, _b; return Metadata_1.Metadata.merge((_a = x.rest) !== null && _a !== void 0 ? _a : x, (_b = y.rest) !== null && _b !== void 0 ? _b : y); }, Metadata_1.Metadata.initialize())), minItems: !!((_a = tuple.type.elements.at(-1)) === null || _a === void 0 ? void 0 : _a.rest) ++ return (__assign(__assign({}, attribute), { type: "array", items: (0, application_v30_schema_1.application_v30_schema)(false)(components)(tuple.type.recursive ? {} : attribute)(tuple.type.elements.reduce(function (x, y) { var _a, _b; return Metadata_1.Metadata.merge((_a = x.rest) !== null && _a !== void 0 ? _a : x, (_b = y.rest) !== null && _b !== void 0 ? _b : y); }, Metadata_1.Metadata.initialize())), minItems: !!((_a = tuple.type.elements.slice(-1)[0]) === null || _a === void 0 ? void 0 : _a.rest) + ? tuple.type.elements.length - 1 +- : tuple.type.elements.filter(function (x) { return !x.optional; }).length, maxItems: !!((_b = tuple.type.elements.at(-1)) === null || _b === void 0 ? void 0 : _b.rest) ++ : tuple.type.elements.filter(function (x) { return !x.optional; }).length, maxItems: !!((_b = tuple.type.elements.slice(-1)[0]) === null || _b === void 0 ? void 0 : _b.rest) + ? undefined + : tuple.type.elements.length })); + }; +diff --git a/lib/programmers/internal/application_v31_tuple.js b/lib/programmers/internal/application_v31_tuple.js +index af7bbbe1536244eec93d7311e289fc8b34245c0f..e7f126b72a3480f761f57e4d43826a26b8b06e3f 100644 +--- a/lib/programmers/internal/application_v31_tuple.js ++++ b/lib/programmers/internal/application_v31_tuple.js +@@ -7,7 +7,7 @@ exports.application_v31_tuple = void 0; + var application_v31_tuple = function (generator) { + return function (tuple) { + var _a, _b; +- var tail = (_b = (_a = tuple.type.elements.at(-1)) === null || _a === void 0 ? void 0 : _a.rest) !== null && _b !== void 0 ? _b : null; ++ var tail = (_b = (_a = tuple.type.elements.slice(-1)[0]) === null || _a === void 0 ? void 0 : _a.rest) !== null && _b !== void 0 ? _b : null; + var prefixItems = tuple.type.isRest() + ? tuple.type.elements.slice(0, -1) + : tuple.type.elements; +diff --git a/lib/programmers/internal/decode_union_object.js b/lib/programmers/internal/decode_union_object.js +index c283bdfdcfb99f26954e6d76d35ccef4f78ddcee..7cdef1aeec80238014cf9457ca4351f02e99b638 100644 +--- a/lib/programmers/internal/decode_union_object.js ++++ b/lib/programmers/internal/decode_union_object.js +@@ -72,7 +72,7 @@ var iterate = function (escaper) { + ? typescript_1.default.factory.createIfStatement(b.condition, typescript_1.default.factory.createReturnStatement(b.value), undefined) + : typescript_1.default.factory.createReturnStatement(b.value); + }); +- if (branches.at(-1).condition !== null) ++ if (branches.slice(-1)[0].condition !== null) + statements.push(escaper(input, expected)); + return typescript_1.default.factory.createBlock(statements, true); + }; diff --git a/lib/programmers/json/JsonStringifyProgrammer.js b/lib/programmers/json/JsonStringifyProgrammer.js -index ce0ae787164f7eba68ef35b05232b4b94ad8e7d7..8f70cfc8c8e9d82cd1ec5004ca5637487f57b3bc 100644 +index 77f2812cb509f5b9093dc311f8ae8558e4469a74..54a6c4e22f9cfa87cd30f8ade50e6cb8ccda9957 100644 --- a/lib/programmers/json/JsonStringifyProgrammer.js +++ b/lib/programmers/json/JsonStringifyProgrammer.js -@@ -424,10 +424,10 @@ var JsonStringifyProgrammer; +@@ -469,10 +469,10 @@ var JsonStringifyProgrammer; var rest = (function () { if (tuple.elements.length === 0) return null; @@ -80,10 +99,10 @@ index ce0ae787164f7eba68ef35b05232b4b94ad8e7d7..8f70cfc8c8e9d82cd1ec5004ca563748 })(); return StringifyJoinder_1.StringifyJoiner.tuple(children, rest); diff --git a/lib/programmers/misc/MiscCloneProgrammer.js b/lib/programmers/misc/MiscCloneProgrammer.js -index 3db6bc92637284468c5fe47ef59f51a9b41d06eb..0b3fa9deaaadf28d4f348225c0d44f49700c1bca 100644 +index 38bec89fba26db7a9c3ee71abd49086692c7e78b..9b9d7a9b0606da78224ce083bcbd7e07cd6ce82e 100644 --- a/lib/programmers/misc/MiscCloneProgrammer.js +++ b/lib/programmers/misc/MiscCloneProgrammer.js -@@ -291,11 +291,11 @@ var MiscCloneProgrammer; +@@ -318,11 +318,11 @@ var MiscCloneProgrammer; var rest = (function () { if (tuple.elements.length === 0) return null; @@ -98,10 +117,10 @@ index 3db6bc92637284468c5fe47ef59f51a9b41d06eb..0b3fa9deaaadf28d4f348225c0d44f49 return CloneJoiner_1.CloneJoiner.tuple(children, rest); }; diff --git a/lib/programmers/misc/MiscPruneProgrammer.js b/lib/programmers/misc/MiscPruneProgrammer.js -index 8440aaba9e449dae2468e96dfd7035ac7e170cfc..e97ceec78427b7eed08db23cc4775fdb10c6b2ff 100644 +index d4a9c66c0b5508b4ffdc4b7684364a9d748f6508..33f9356bab69faffadb8c2b49997d2c3ca429810 100644 --- a/lib/programmers/misc/MiscPruneProgrammer.js +++ b/lib/programmers/misc/MiscPruneProgrammer.js -@@ -272,11 +272,11 @@ var MiscPruneProgrammer; +@@ -305,11 +305,11 @@ var MiscPruneProgrammer; var rest = (function () { if (tuple.elements.length === 0) return null; @@ -116,10 +135,10 @@ index 8440aaba9e449dae2468e96dfd7035ac7e170cfc..e97ceec78427b7eed08db23cc4775fdb return PruneJoiner_1.PruneJoiner.tuple(children, rest); }; diff --git a/lib/programmers/notations/NotationGeneralProgrammer.js b/lib/programmers/notations/NotationGeneralProgrammer.js -index 6e0b582a802180d7671c00b999469e7e59193b30..f11cc1d523875a040d3e27ce9a850b083c5d0275 100644 +index dfe64a21a5a81a7e887ab5ae02d73e6d3bdddb03..aa4b6070ed6a83c49018384e3a0c1dbd4a7c540b 100644 --- a/lib/programmers/notations/NotationGeneralProgrammer.js +++ b/lib/programmers/notations/NotationGeneralProgrammer.js -@@ -301,11 +301,11 @@ var NotationGeneralProgrammer; +@@ -328,11 +328,11 @@ var NotationGeneralProgrammer; var rest = (function () { if (tuple.elements.length === 0) return null; @@ -134,36 +153,36 @@ index 6e0b582a802180d7671c00b999469e7e59193b30..f11cc1d523875a040d3e27ce9a850b08 return NotationJoiner_1.NotationJoiner.tuple(children, rest); }; diff --git a/lib/transformers/CallExpressionTransformer.js b/lib/transformers/CallExpressionTransformer.js -index 2c5a23879d171ee271ebf6857dc9c65ec29c0ea7..96a40845614f6c54fe8e4ebc48a7d8efeba52a41 100644 +index f7be23d98552526d8c2348ba0f3d32b8d31e522b..133af0caa37ffcf7330811ef7bda79e75b9ecd89 100644 --- a/lib/transformers/CallExpressionTransformer.js +++ b/lib/transformers/CallExpressionTransformer.js -@@ -101,7 +101,7 @@ var CallExpressionTransformer; - var location = path_1.default.resolve(declaration.getSourceFile().fileName); - if (isTarget(location) === false) - return expression; +@@ -129,7 +129,7 @@ var CallExpressionTransformer; + // TRANSFORMATION + //---- + // FUNCTION NAME - var module = location.split(path_1.default.sep).at(-1).split(".")[0]; + var module = location.split(path_1.default.sep).slice(-1)[0].split(".")[0]; var name = project.checker.getTypeAtLocation(declaration).symbol.name; + // FIND TRANSFORMER var functor = (_b = FUNCTORS[module]) === null || _b === void 0 ? void 0 : _b[name]; - if (functor === undefined) diff --git a/src/factories/internal/metadata/iterate_metadata_intersection.ts b/src/factories/internal/metadata/iterate_metadata_intersection.ts -index f46caa25c987092597073e046ae3b9e8130bd994..1eedd727c74f173a5b98a9572b865e058885811d 100644 +index c4d93a961385c09abb6f448896ad4636b648703b..99b1547e6a501caf28a452390fe721cd47dc2ca1 100644 --- a/src/factories/internal/metadata/iterate_metadata_intersection.ts +++ b/src/factories/internal/metadata/iterate_metadata_intersection.ts -@@ -214,7 +214,7 @@ export const iterate_metadata_intersection = +@@ -188,7 +188,7 @@ export const iterate_metadata_intersection = target, )(objects.map((om) => om.objects).flat(), explore); if (tags.length) - if (target === "array") meta.arrays.at(-1)!.tags.push(tags); + if (target === "array") meta.arrays.slice(-1)[0]!.tags.push(tags); - else if (booleanLiteral === null) + else if (atomics.size) meta.atomics.find((a) => a.type === target)!.tags.push(tags); - else { + else if (constants.length) { diff --git a/src/programmers/CheckerProgrammer.ts b/src/programmers/CheckerProgrammer.ts -index 892748b80755b89d1449f4d515aa3166534c6b19..8cb5ce35fe6f918545c82066f0583dead2661c89 100644 +index 40f46e8212a5173e19e0214422086655de908933..18a1a2371cac697e1b621a8fbc6b090b691e3072 100644 --- a/src/programmers/CheckerProgrammer.ts +++ b/src/programmers/CheckerProgrammer.ts -@@ -702,14 +702,14 @@ export namespace CheckerProgrammer { +@@ -785,14 +785,14 @@ export namespace CheckerProgrammer { ), ); const rest: ts.Expression | null = @@ -181,47 +200,66 @@ index 892748b80755b89d1449f4d515aa3166534c6b19..8cb5ce35fe6f918545c82066f0583dea ...explore, start: tuple.elements.length - 1, diff --git a/src/programmers/TypiaProgrammer.ts b/src/programmers/TypiaProgrammer.ts -index e01eccf62eccd73e1f0720db897f539256a6bbc1..cae5eb6fc702d359d4886acefdb68d42691edf97 100644 +index 67d9fc138483832aae43574fd2753bbe40a27d14..4397517aa620a8733c51917eebfa467f2922bf6d 100644 --- a/src/programmers/TypiaProgrammer.ts +++ b/src/programmers/TypiaProgrammer.ts @@ -101,7 +101,7 @@ export namespace TypiaProgrammer { - .file!.text.substring(0, diag.start) - .split("\n"); - if (lines.length === 0) return [0, 0]; -- return [lines.length, lines.at(-1)!.length + 1]; -+ return [lines.length, lines.slice(-1)[0]!.length + 1]; - })() - : [0, 0]; - console.error( -diff --git a/src/programmers/internal/application_tuple.ts b/src/programmers/internal/application_tuple.ts -index 5e10b9051e4a846f298aa8f086109e8d6bb38bf9..a8e24d5c2a2a4a4d5d1dc49eb45b4784654a4b66 100644 ---- a/src/programmers/internal/application_tuple.ts -+++ b/src/programmers/internal/application_tuple.ts -@@ -28,16 +28,16 @@ export const application_tuple = - }), + .file!.text.substring(0, diag.start) + .split("\n"); + if (lines.length === 0) return [0, 0]; +- return [lines.length, lines.at(-1)!.length + 1]; ++ return [lines.length, lines.slice(-1)[0]!.length + 1]; + })() + : [0, 0]; + console.error( +diff --git a/src/programmers/internal/application_v30_tuple.ts b/src/programmers/internal/application_v30_tuple.ts +index 0431273d439c6069a1bb5fbfd7808c5e8d0ea255..4b27cfc3ebde7ce9dcdb5161d34e70004a327b1e 100644 +--- a/src/programmers/internal/application_v30_tuple.ts ++++ b/src/programmers/internal/application_v30_tuple.ts +@@ -24,10 +24,10 @@ export const application_v30_tuple = + Metadata.initialize(), ), - ...attribute, -- minItems: !!tuple.type.elements.at(-1)?.rest -+ minItems: !!tuple.type.elements.slice(-1)[0]?.rest - ? tuple.type.elements.length - 1 - : tuple.type.elements.filter((x) => !x.optional).length, -- maxItems: !!tuple.type.elements.at(-1)?.rest -+ maxItems: !!tuple.type.elements.slice(-1)[0]?.rest - ? undefined - : tuple.type.elements.length, - }; - if (options.purpose === "ajv") - if (tuple.type.elements.length === 0) return schema; -- else if (!tuple.type.elements.at(-1)?.rest) return schema; -+ else if (!tuple.type.elements.slice(-1)[0]?.rest) return schema; - - const wrapper: IJsonSchema.IArray = { - ...schema, + ), +- minItems: !!tuple.type.elements.at(-1)?.rest ++ minItems: !!tuple.type.elements.slice(-1)[0]?.rest + ? tuple.type.elements.length - 1 + : tuple.type.elements.filter((x) => !x.optional).length, +- maxItems: !!tuple.type.elements.at(-1)?.rest ++ maxItems: !!tuple.type.elements.slice(-1)[0]?.rest + ? undefined! + : tuple.type.elements.length, + }); +diff --git a/src/programmers/internal/application_v31_tuple.ts b/src/programmers/internal/application_v31_tuple.ts +index 426abad3423de706c368b35b2cf6b4845f6f3d91..be15ec0fda1725bf1ea882c9901e0f837c052fde 100644 +--- a/src/programmers/internal/application_v31_tuple.ts ++++ b/src/programmers/internal/application_v31_tuple.ts +@@ -9,7 +9,7 @@ import { MetadataTuple } from "../../schemas/metadata/MetadataTuple"; + export const application_v31_tuple = + (generator: (meta: Metadata) => OpenApi.IJsonSchema) => + (tuple: MetadataTuple): OpenApi.IJsonSchema.ITuple => { +- const tail: Metadata | null = tuple.type.elements.at(-1)?.rest ?? null; ++ const tail: Metadata | null = tuple.type.elements.slice(-1)[0]?.rest ?? null; + const prefixItems: Metadata[] = tuple.type.isRest() + ? tuple.type.elements.slice(0, -1) + : tuple.type.elements; +diff --git a/src/programmers/internal/decode_union_object.ts b/src/programmers/internal/decode_union_object.ts +index f60bf69f91f35dee2efc807475fd6eca71aab052..ef8d51160f7eb9853ec0c827827aaa6c65db1587 100644 +--- a/src/programmers/internal/decode_union_object.ts ++++ b/src/programmers/internal/decode_union_object.ts +@@ -87,7 +87,7 @@ const iterate = + ) + : ts.factory.createReturnStatement(b.value), + ); +- if (branches.at(-1)!.condition !== null) ++ if (branches.slice(-1)[0]!.condition !== null) + statements.push(escaper(input, expected)); + return ts.factory.createBlock(statements, true); + }; diff --git a/src/programmers/json/JsonStringifyProgrammer.ts b/src/programmers/json/JsonStringifyProgrammer.ts -index c317cec2c78e984a6e64c7bf287d0c67e530e309..5974830c62dbd2b865aa2e64e2e757283258d872 100644 +index 558e5bf4b79f5cc28791ba0f5e40ebe6599361ce..c43d77b5d15343af90f7362d1757fc758659d5c9 100644 --- a/src/programmers/json/JsonStringifyProgrammer.ts +++ b/src/programmers/json/JsonStringifyProgrammer.ts -@@ -543,7 +543,7 @@ export namespace JsonStringifyProgrammer { +@@ -560,7 +560,7 @@ export namespace JsonStringifyProgrammer { ); const rest = (() => { if (tuple.elements.length === 0) return null; @@ -230,7 +268,7 @@ index c317cec2c78e984a6e64c7bf287d0c67e530e309..5974830c62dbd2b865aa2e64e2e75728 if (last.rest === null) return null; const code = decode(project)(config)(importer)( -@@ -552,7 +552,7 @@ export namespace JsonStringifyProgrammer { +@@ -569,7 +569,7 @@ export namespace JsonStringifyProgrammer { undefined, [ExpressionFactory.number(tuple.elements.length - 1)], ), @@ -240,10 +278,10 @@ index c317cec2c78e984a6e64c7bf287d0c67e530e309..5974830c62dbd2b865aa2e64e2e75728 ...explore, start: tuple.elements.length - 1, diff --git a/src/programmers/misc/MiscCloneProgrammer.ts b/src/programmers/misc/MiscCloneProgrammer.ts -index 94d768b0a0738c0caccd711671351d1f22fa3848..739fd5f2baf4d2eb8e9dd65d73179242a0244707 100644 +index c8c9cb90085eff7dd68ac332a362674ca33d93d8..76a810816bc4ad57ff5e1787a33cd7f01471ffbe 100644 --- a/src/programmers/misc/MiscCloneProgrammer.ts +++ b/src/programmers/misc/MiscCloneProgrammer.ts -@@ -343,7 +343,7 @@ export namespace MiscCloneProgrammer { +@@ -395,7 +395,7 @@ export namespace MiscCloneProgrammer { const rest = (() => { if (tuple.elements.length === 0) return null; @@ -252,7 +290,7 @@ index 94d768b0a0738c0caccd711671351d1f22fa3848..739fd5f2baf4d2eb8e9dd65d73179242 const rest: Metadata | null = last.rest; if (rest === null) return null; -@@ -353,7 +353,7 @@ export namespace MiscCloneProgrammer { +@@ -405,7 +405,7 @@ export namespace MiscCloneProgrammer { undefined, [ExpressionFactory.number(tuple.elements.length - 1)], ), @@ -262,10 +300,10 @@ index 94d768b0a0738c0caccd711671351d1f22fa3848..739fd5f2baf4d2eb8e9dd65d73179242 ...explore, start: tuple.elements.length - 1, diff --git a/src/programmers/misc/MiscPruneProgrammer.ts b/src/programmers/misc/MiscPruneProgrammer.ts -index ed1465267066e382ae6696a25a806c2489597593..661f3cd93ae66070c978bd3e8d2b8db07189fe47 100644 +index 1051204a00041ddfb39da9de77b35ab8b44b75ee..73db30fdc06955f43dc2f563cbfc174e50a1bc6f 100644 --- a/src/programmers/misc/MiscPruneProgrammer.ts +++ b/src/programmers/misc/MiscPruneProgrammer.ts -@@ -310,7 +310,7 @@ export namespace MiscPruneProgrammer { +@@ -347,7 +347,7 @@ export namespace MiscPruneProgrammer { const rest = (() => { if (tuple.elements.length === 0) return null; @@ -274,7 +312,7 @@ index ed1465267066e382ae6696a25a806c2489597593..661f3cd93ae66070c978bd3e8d2b8db0 const rest: Metadata | null = last.rest; if (rest === null || filter(rest) === false) return null; -@@ -320,7 +320,7 @@ export namespace MiscPruneProgrammer { +@@ -357,7 +357,7 @@ export namespace MiscPruneProgrammer { undefined, [ExpressionFactory.number(tuple.elements.length - 1)], ), @@ -284,10 +322,10 @@ index ed1465267066e382ae6696a25a806c2489597593..661f3cd93ae66070c978bd3e8d2b8db0 ...explore, start: tuple.elements.length - 1, diff --git a/src/programmers/notations/NotationGeneralProgrammer.ts b/src/programmers/notations/NotationGeneralProgrammer.ts -index bd49b1e34002b1a1ec4f5444a8f91fa0ab794360..71d676de290986045910602ab10c6ef09a19c07d 100644 +index d8b2e22a8f9f3bfcb8f3e7987edaa7bf19a48720..96632214cb02b1534dc1987a0f892a3bf41e892f 100644 --- a/src/programmers/notations/NotationGeneralProgrammer.ts +++ b/src/programmers/notations/NotationGeneralProgrammer.ts -@@ -353,7 +353,7 @@ export namespace NotationGeneralProgrammer { +@@ -411,7 +411,7 @@ export namespace NotationGeneralProgrammer { const rest = (() => { if (tuple.elements.length === 0) return null; @@ -296,7 +334,7 @@ index bd49b1e34002b1a1ec4f5444a8f91fa0ab794360..71d676de290986045910602ab10c6ef0 const rest: Metadata | null = last.rest; if (rest === null) return null; -@@ -363,7 +363,7 @@ export namespace NotationGeneralProgrammer { +@@ -421,7 +421,7 @@ export namespace NotationGeneralProgrammer { undefined, [ExpressionFactory.number(tuple.elements.length - 1)], ), @@ -306,15 +344,15 @@ index bd49b1e34002b1a1ec4f5444a8f91fa0ab794360..71d676de290986045910602ab10c6ef0 ...explore, start: tuple.elements.length - 1, diff --git a/src/transformers/CallExpressionTransformer.ts b/src/transformers/CallExpressionTransformer.ts -index c58a1b143ce4f204bb249a4858c9d16a26f97408..9e9ffcf73e4c01aa6ac8c213669fdcd50e0181b9 100644 +index 99a4604f1a1944336b4d93dc61390269c346c243..c31ba72f1d206c441d6c237314a1c4d5c808dd09 100644 --- a/src/transformers/CallExpressionTransformer.ts +++ b/src/transformers/CallExpressionTransformer.ts -@@ -111,7 +111,7 @@ export namespace CallExpressionTransformer { - // TRANSFORMATION - //---- - // FUNCTION NAME -- const module: string = location.split(path.sep).at(-1)!.split(".")[0]!; -+ const module: string = location.split(path.sep).slice(-1)[0]!.split(".")[0]!; - const { name } = project.checker.getTypeAtLocation(declaration).symbol; - - // FIND TRANSFORMER +@@ -131,7 +131,7 @@ export namespace CallExpressionTransformer { + // TRANSFORMATION + //---- + // FUNCTION NAME +- const module: string = location.split(path.sep).at(-1)!.split(".")[0]!; ++ const module: string = location.split(path.sep).slice(-1)[0]!.split(".")[0]!; + const { name } = project.checker.getTypeAtLocation(declaration).symbol; + + // FIND TRANSFORMER diff --git a/apps/meteor/client/hooks/useEndpointAction.ts b/apps/meteor/client/hooks/useEndpointAction.ts index c7c371a04e1f0..2cfb22b185485 100644 --- a/apps/meteor/client/hooks/useEndpointAction.ts +++ b/apps/meteor/client/hooks/useEndpointAction.ts @@ -15,7 +15,7 @@ type UseEndpointActionOptions = (undefined ext export function useEndpointAction( method: TMethod, pathPattern: TPathPattern, - options: UseEndpointActionOptions = { keys: {} as UrlParams }, + options: NoInfer> = { keys: {} as UrlParams }, ) { const sendData = useEndpoint(method, pathPattern, options.keys as UrlParams); diff --git a/apps/meteor/client/hooks/useEndpointData.ts b/apps/meteor/client/hooks/useEndpointData.ts index 6e759ad587e5a..93942946ede03 100644 --- a/apps/meteor/client/hooks/useEndpointData.ts +++ b/apps/meteor/client/hooks/useEndpointData.ts @@ -20,11 +20,11 @@ const deprecationWarning = log('useEndpointData is deprecated, use @tanstack/rea */ export const useEndpointData = ( endpoint: TPathPattern, - options: { + options: NoInfer<{ keys?: UrlParams; params?: OperationParams<'GET', TPathPattern>; initialValue?: Serialized> | (() => Serialized>); - } = {}, + }> = {}, ): AsyncState>> & { reload: () => void; } => { diff --git a/apps/meteor/client/lib/createRouteGroup.tsx b/apps/meteor/client/lib/createRouteGroup.tsx index e418ecc56e998..70eab4782dd19 100644 --- a/apps/meteor/client/lib/createRouteGroup.tsx +++ b/apps/meteor/client/lib/createRouteGroup.tsx @@ -1,4 +1,4 @@ -import { type IRouterPaths, type RouteName, type RouterPathPattern } from '@rocket.chat/ui-contexts'; +import type { IRouterPaths, RouteName, RouterPathPattern } from '@rocket.chat/ui-contexts'; import React, { type ElementType, type ReactNode } from 'react'; import { router } from '../providers/RouterProvider'; @@ -9,21 +9,21 @@ type GroupName = 'omnichannel' | 'marketplace' | 'account' | 'admin'; type GroupPrefix = IRouterPaths[`${TGroupName}-index`]['pattern']; -type RouteNamesOf = Extract< +type RouteNamesOf = ( | keyof { [TRouteName in RouteName as IRouterPaths[TRouteName]['pattern'] extends `${GroupPrefix}/${string}` ? TRouteName : never]: never; } - | `${GroupName}-index`, - RouteName ->; + | `${GroupName}-index` +) & + RouteName; -type TrimPrefix = T extends `${P}${infer U}` ? U : T; +type TrimPrefix = T extends `${P}${infer U}` ? U : T; export const createRouteGroup = ( name: TGroupName, - prefix: GroupPrefix, + prefix: NoInfer>, RouterComponent: ElementType<{ children?: ReactNode; }>, diff --git a/apps/meteor/client/lib/getLocalePercentage.ts b/apps/meteor/client/lib/getLocalePercentage.ts index e6f2fa3bbff1a..3aa84b59f03fb 100644 --- a/apps/meteor/client/lib/getLocalePercentage.ts +++ b/apps/meteor/client/lib/getLocalePercentage.ts @@ -1,9 +1,6 @@ -export const getLocalePercentage = (locale: string, total: number, fraction: number, decimalCount = 2): string => { - const option = { +export const getLocalePercentage = (locale: string, total: number, fraction: number, decimalCount = 2) => + new Intl.NumberFormat(locale, { style: 'percent', minimumFractionDigits: decimalCount, maximumFractionDigits: decimalCount, - }; - - return new Intl.NumberFormat(locale, option).format(fraction / total); -}; + }).format(fraction / total); diff --git a/apps/meteor/client/providers/CallProvider/CallProvider.tsx b/apps/meteor/client/providers/CallProvider/CallProvider.tsx index f2c884aeb05ff..6e728dc35eb61 100644 --- a/apps/meteor/client/providers/CallProvider/CallProvider.tsx +++ b/apps/meteor/client/providers/CallProvider/CallProvider.tsx @@ -11,7 +11,7 @@ import { } from '@rocket.chat/core-typings'; import { useMutableCallback } from '@rocket.chat/fuselage-hooks'; import { Random } from '@rocket.chat/random'; -import type { Device, IExperimentalHTMLAudioElement } from '@rocket.chat/ui-contexts'; +import type { Device } from '@rocket.chat/ui-contexts'; import { useRouter, useUser, @@ -65,7 +65,7 @@ export const CallProvider = ({ children }: CallProviderProps) => { const hasVoIPEnterpriseLicense = useIsVoipEnterprise(); - const remoteAudioMediaRef = useRef(null); // TODO: Create a dedicated file for the AUDIO and make the controls accessible + const remoteAudioMediaRef = useRef(null); // TODO: Create a dedicated file for the AUDIO and make the controls accessible const [queueCounter, setQueueCounter] = useState(0); const [queueName, setQueueName] = useState(''); diff --git a/apps/meteor/client/providers/DeviceProvider/DeviceProvider.tsx b/apps/meteor/client/providers/DeviceProvider/DeviceProvider.tsx index 90ced3b0459ac..c8fd77fa257b1 100644 --- a/apps/meteor/client/providers/DeviceProvider/DeviceProvider.tsx +++ b/apps/meteor/client/providers/DeviceProvider/DeviceProvider.tsx @@ -1,5 +1,5 @@ import { useMutableCallback } from '@rocket.chat/fuselage-hooks'; -import type { Device, IExperimentalHTMLAudioElement, DeviceContextValue } from '@rocket.chat/ui-contexts'; +import type { Device, DeviceContextValue } from '@rocket.chat/ui-contexts'; import { DeviceContext } from '@rocket.chat/ui-contexts'; import type { ReactElement, ReactNode } from 'react'; import React, { useEffect, useState, useMemo } from 'react'; @@ -33,7 +33,7 @@ export const DeviceProvider = ({ children }: DeviceProviderProps): ReactElement }; const setAudioOutputDevice = useMutableCallback( - ({ outputDevice, HTMLAudioElement }: { outputDevice: Device; HTMLAudioElement: IExperimentalHTMLAudioElement }): void => { + ({ outputDevice, HTMLAudioElement }: { outputDevice: Device; HTMLAudioElement: HTMLAudioElement }): void => { if (!isSetSinkIdAvailable()) { throw new Error('setSinkId is not available in this browser'); } diff --git a/apps/meteor/client/providers/DeviceProvider/lib/isSetSinkIdAvailable.tsx b/apps/meteor/client/providers/DeviceProvider/lib/isSetSinkIdAvailable.tsx index 65bf99ed116fc..2f835819afe6a 100644 --- a/apps/meteor/client/providers/DeviceProvider/lib/isSetSinkIdAvailable.tsx +++ b/apps/meteor/client/providers/DeviceProvider/lib/isSetSinkIdAvailable.tsx @@ -1,6 +1,4 @@ -import type { IExperimentalHTMLAudioElement } from '@rocket.chat/ui-contexts'; - export const isSetSinkIdAvailable = (): boolean => { - const audio = new Audio() as IExperimentalHTMLAudioElement; + const audio = new Audio(); return !!audio.setSinkId; }; diff --git a/apps/meteor/client/providers/TranslationProvider.tsx b/apps/meteor/client/providers/TranslationProvider.tsx index 0c0ef00b5ac08..eb546c91c6bdf 100644 --- a/apps/meteor/client/providers/TranslationProvider.tsx +++ b/apps/meteor/client/providers/TranslationProvider.tsx @@ -84,7 +84,7 @@ const useI18next = (lng: string): typeof i18next => { loadPath: 'i18n/{{lng}}.json', parse: (data: string, _lngs?: string | string[], namespaces: string | string[] = []) => extractTranslationKeys(JSON.parse(data), namespaces), - request: (_options, url, _payload, callback) => { + request: (_options: unknown, url: string, _payload: unknown, callback: (error: unknown, data: unknown) => void) => { const params = url.split('/'); const lng = params[params.length - 1]; diff --git a/apps/meteor/client/views/admin/viewLogs/ansispan.ts b/apps/meteor/client/views/admin/viewLogs/ansispan.ts index 7f1709e48ef21..8aa5bccb11954 100644 --- a/apps/meteor/client/views/admin/viewLogs/ansispan.ts +++ b/apps/meteor/client/views/admin/viewLogs/ansispan.ts @@ -1,3 +1,4 @@ +/* eslint-disable no-control-regex */ const foregroundColors = { 30: 'var(--rcx-color-font-secondary-info, #6C727A)', 31: 'var(--rcx-color-font-danger, #D40C26)', @@ -16,13 +17,13 @@ export const ansispan = (str: string): string => { .replace(/>/g, '>') .replace(/$1') - .replace(/\033\[1m/g, '') - .replace(/\033\[22m/g, '') - .replace(/\033\[3m/g, '') - .replace(/\033\[23m/g, '') - .replace(/\033\[m/g, '') - .replace(/\033\[0m/g, '') - .replace(/\033\[39m/g, ''); + .replace(/\x1b\[1m/g, '') + .replace(/\x1b\[22m/g, '') + .replace(/\x1b\[3m/g, '') + .replace(/\x1b\[23m/g, '') + .replace(/\x1b\[m/g, '') + .replace(/\x1b\[0m/g, '') + .replace(/\x1b\[39m/g, ''); return Object.entries(foregroundColors).reduce((str, [ansiCode, color]) => { const span = ``; return str.replace(new RegExp(`\\033\\[${ansiCode}m`, 'g'), span).replace(new RegExp(`\\033\\[0;${ansiCode}m`, 'g'), span); diff --git a/apps/meteor/ee/server/services/package.json b/apps/meteor/ee/server/services/package.json index 58b73351c4e00..27794da80e16e 100644 --- a/apps/meteor/ee/server/services/package.json +++ b/apps/meteor/ee/server/services/package.json @@ -62,7 +62,7 @@ "pino-pretty": "^7.6.1", "pm2": "^5.2.0", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "volta": { "extends": "../../../package.json" diff --git a/apps/meteor/package.json b/apps/meteor/package.json index 9c49c2cb33f8e..b1230a0fa8135 100644 --- a/apps/meteor/package.json +++ b/apps/meteor/package.json @@ -210,7 +210,7 @@ "supports-color": "~7.2.0", "template-file": "^6.0.1", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "dependencies": { "@babel/runtime": "~7.22.15", @@ -430,7 +430,7 @@ "turndown": "^7.1.2", "twilio": "^3.76.1", "twit": "^2.2.11", - "typia": "^5.3.3", + "typia": "~6.9.0", "ua-parser-js": "^1.0.37", "underscore": "^1.13.6", "universal-perf-hooks": "^1.0.1", diff --git a/apps/meteor/server/services/federation/Federation.ts b/apps/meteor/server/services/federation/Federation.ts index c8e2a9b1bc57e..34331dc009718 100644 --- a/apps/meteor/server/services/federation/Federation.ts +++ b/apps/meteor/server/services/federation/Federation.ts @@ -17,7 +17,9 @@ const allowedActionsInFederatedRooms: ValueOf[] = [ RoomMemberActions.LEAVE, ]; -const allowedActionsForModerators = allowedActionsInFederatedRooms.filter((action) => action !== RoomMemberActions.SET_AS_OWNER); +const allowedActionsForModerators: ValueOf[] = allowedActionsInFederatedRooms.filter( + (action) => action !== RoomMemberActions.SET_AS_OWNER, +); const allowedRoomSettingsChangesInFederatedRooms: ValueOf[] = [RoomSettingsEnum.NAME, RoomSettingsEnum.TOPIC]; diff --git a/ee/apps/account-service/package.json b/ee/apps/account-service/package.json index ac28eb76e76d5..c0c3dab2ef8ca 100644 --- a/ee/apps/account-service/package.json +++ b/ee/apps/account-service/package.json @@ -45,7 +45,7 @@ "@types/polka": "^0.5.6", "eslint": "~8.45.0", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./dist/ee/apps/account-service/src/service.js", "files": [ diff --git a/ee/apps/authorization-service/package.json b/ee/apps/authorization-service/package.json index bff15e7f7d91e..ab1429fd0223e 100644 --- a/ee/apps/authorization-service/package.json +++ b/ee/apps/authorization-service/package.json @@ -41,7 +41,7 @@ "@types/polka": "^0.5.6", "eslint": "~8.45.0", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./dist/ee/apps/authorization-service/src/service.js", "files": [ diff --git a/ee/apps/ddp-streamer/package.json b/ee/apps/ddp-streamer/package.json index 1687042e0d313..fab1967867da0 100644 --- a/ee/apps/ddp-streamer/package.json +++ b/ee/apps/ddp-streamer/package.json @@ -57,7 +57,7 @@ "eslint": "~8.45.0", "pino-pretty": "^7.6.1", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./dist/service.js", "files": [ diff --git a/ee/apps/omnichannel-transcript/package.json b/ee/apps/omnichannel-transcript/package.json index c60542c180ec5..959ea0605c02e 100644 --- a/ee/apps/omnichannel-transcript/package.json +++ b/ee/apps/omnichannel-transcript/package.json @@ -47,7 +47,7 @@ "@types/polka": "^0.5.6", "eslint": "~8.45.0", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./dist/ee/apps/omnichannel-transcript/src/service.js", "files": [ diff --git a/ee/apps/presence-service/package.json b/ee/apps/presence-service/package.json index c800dd4d6c800..49653f0dcbafe 100644 --- a/ee/apps/presence-service/package.json +++ b/ee/apps/presence-service/package.json @@ -41,7 +41,7 @@ "@types/polka": "^0.5.6", "eslint": "~8.45.0", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./dist/ee/apps/presence-service/src/service.js", "files": [ diff --git a/ee/apps/queue-worker/package.json b/ee/apps/queue-worker/package.json index 0a227cb271c00..19b252b70601c 100644 --- a/ee/apps/queue-worker/package.json +++ b/ee/apps/queue-worker/package.json @@ -45,7 +45,7 @@ "@types/polka": "^0.5.6", "eslint": "~8.45.0", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./dist/ee/apps/queue-worker/src/service.js", "files": [ diff --git a/ee/apps/stream-hub-service/package.json b/ee/apps/stream-hub-service/package.json index 812522a5f1d89..069e58586fe7c 100644 --- a/ee/apps/stream-hub-service/package.json +++ b/ee/apps/stream-hub-service/package.json @@ -43,7 +43,7 @@ "@types/polka": "^0.5.6", "eslint": "~8.45.0", "ts-node": "^10.9.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./dist/ee/apps/stream-hub-service/src/service.js", "files": [ diff --git a/ee/packages/license/package.json b/ee/packages/license/package.json index 1c746514d443d..76d18fc35a8e4 100644 --- a/ee/packages/license/package.json +++ b/ee/packages/license/package.json @@ -10,7 +10,7 @@ "eslint": "~8.45.0", "jest": "~29.7.0", "jest-websocket-mock": "~2.5.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "tsc", diff --git a/ee/packages/omnichannel-services/package.json b/ee/packages/omnichannel-services/package.json index f520d82bd7d31..6e9c80ae02ea6 100644 --- a/ee/packages/omnichannel-services/package.json +++ b/ee/packages/omnichannel-services/package.json @@ -8,7 +8,7 @@ "@types/jest": "~29.5.12", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "dependencies": { "@rocket.chat/core-services": "workspace:^", diff --git a/ee/packages/pdf-worker/package.json b/ee/packages/pdf-worker/package.json index 749d48ccc9c2a..9c58aff464bd2 100644 --- a/ee/packages/pdf-worker/package.json +++ b/ee/packages/pdf-worker/package.json @@ -14,7 +14,7 @@ "eslint": "~8.45.0", "jest": "~29.7.0", "react-dom": "~18.3.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "tsc -p tsconfig.build.json && cp -r src/public dist/public", diff --git a/ee/packages/presence/package.json b/ee/packages/presence/package.json index 787eb2053007b..997f80c60dd7b 100644 --- a/ee/packages/presence/package.json +++ b/ee/packages/presence/package.json @@ -13,7 +13,7 @@ "babel-jest": "^29.0.3", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint src", diff --git a/ee/packages/ui-theming/package.json b/ee/packages/ui-theming/package.json index 713265b36bfa5..2c5e6c41267d8 100644 --- a/ee/packages/ui-theming/package.json +++ b/ee/packages/ui-theming/package.json @@ -16,7 +16,7 @@ "eslint-plugin-testing-library": "^5.11.1", "react": "~17.0.2", "react-docgen-typescript-plugin": "~1.0.5", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/package.json b/package.json index 29de436373e20..7cb5f88cdbe9d 100644 --- a/package.json +++ b/package.json @@ -64,8 +64,7 @@ "@storybook/react-docgen-typescript-plugin@1.0.2-canary.6.9d540b91e815f8fc2f8829189deb00553559ff63.0": "patch:@storybook/react-docgen-typescript-plugin@npm%3A1.0.2-canary.6.9d540b91e815f8fc2f8829189deb00553559ff63.0#./.yarn/patches/@storybook-react-docgen-typescript-plugin-npm-1.0.2-canary.6.9d540b91e815f8fc2f8829189deb00553559ff63.0-b31cc57c40.patch", "mongodb@^4.17.1": "patch:mongodb@npm:4.17.1#.yarn/patches/mongodb-npm-4.17.1-a2fe811ff1.patch", "@rocket.chat/forked-matrix-sdk-crypto-nodejs": "0.1.0-beta.13", - "typia@5.3.3": "patch:typia@npm:5.3.3#.yarn/patches/typia-npm-5.3.3-21d3e18463.patch", - "typia@~5.3.3": "patch:typia@npm%3A5.3.3#./.yarn/patches/typia-npm-5.3.3-21d3e18463.patch" + "typia@~6.9.0": "patch:typia@npm%3A6.9.0#./.yarn/patches/typia-npm-6.9.0-2fd4d85f25.patch" }, "dependencies": { "node-gyp": "^9.4.1" diff --git a/packages/account-utils/package.json b/packages/account-utils/package.json index e33876a02d283..4ec6cd3bcab5e 100644 --- a/packages/account-utils/package.json +++ b/packages/account-utils/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/agenda/package.json b/packages/agenda/package.json index 71b8b01bd6b06..f09921de6c316 100644 --- a/packages/agenda/package.json +++ b/packages/agenda/package.json @@ -14,7 +14,7 @@ "devDependencies": { "@types/debug": "^4.1.10", "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/api-client/package.json b/packages/api-client/package.json index 43de20583d471..6d84bfe46f7e6 100644 --- a/packages/api-client/package.json +++ b/packages/api-client/package.json @@ -8,7 +8,7 @@ "eslint": "~8.45.0", "jest": "~29.7.0", "jest-fetch-mock": "^3.0.3", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "tsc", diff --git a/packages/apps/package.json b/packages/apps/package.json index 816e271535df3..4491237dc0476 100644 --- a/packages/apps/package.json +++ b/packages/apps/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/base64/package.json b/packages/base64/package.json index c58a652877a3d..441fed0e06c14 100644 --- a/packages/base64/package.json +++ b/packages/base64/package.json @@ -21,7 +21,7 @@ "@typescript-eslint/parser": "~5.60.1", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "volta": { "extends": "../../package.json" diff --git a/packages/cas-validate/package.json b/packages/cas-validate/package.json index 769b74d38e562..a7cccb9117814 100644 --- a/packages/cas-validate/package.json +++ b/packages/cas-validate/package.json @@ -5,7 +5,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/core-services/package.json b/packages/core-services/package.json index fe1d4ef0dceaf..281982a62c577 100644 --- a/packages/core-services/package.json +++ b/packages/core-services/package.json @@ -16,7 +16,7 @@ "jest": "~29.7.0", "mongodb": "^4.17.2", "prettier": "~2.8.8", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/core-typings/package.json b/packages/core-typings/package.json index 34bdc67438ca7..98d496c05054b 100644 --- a/packages/core-typings/package.json +++ b/packages/core-typings/package.json @@ -7,7 +7,7 @@ "eslint": "~8.45.0", "mongodb": "^4.17.2", "prettier": "~2.8.8", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/cron/package.json b/packages/cron/package.json index a6484224ded5f..3003eacb39dc4 100644 --- a/packages/cron/package.json +++ b/packages/cron/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/ddp-client/package.json b/packages/ddp-client/package.json index 9e4fdfd859102..5d8ef8867497e 100644 --- a/packages/ddp-client/package.json +++ b/packages/ddp-client/package.json @@ -8,7 +8,7 @@ "eslint": "~8.45.0", "jest": "~29.7.0", "jest-websocket-mock": "~2.5.0", - "typescript": "~5.3.3", + "typescript": "~5.5.4", "ws": "^8.13.0" }, "peerDependencies": { diff --git a/packages/favicon/package.json b/packages/favicon/package.json index b61eaee02a688..67f5c6dcdfea0 100644 --- a/packages/favicon/package.json +++ b/packages/favicon/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/fuselage-ui-kit/package.json b/packages/fuselage-ui-kit/package.json index 9431a0c19d964..688033a1a7dc4 100644 --- a/packages/fuselage-ui-kit/package.json +++ b/packages/fuselage-ui-kit/package.json @@ -106,7 +106,7 @@ "rimraf": "^3.0.2", "storybook-dark-mode": "~3.0.1", "tslib": "^2.5.3", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "dependencies": { "@rocket.chat/core-typings": "workspace:^", diff --git a/packages/gazzodown/package.json b/packages/gazzodown/package.json index 6ecb49fa9544e..d025320e68741 100644 --- a/packages/gazzodown/package.json +++ b/packages/gazzodown/package.json @@ -41,7 +41,7 @@ "outdent": "^0.8.0", "react-docgen-typescript-plugin": "~1.0.5", "react-dom": "~17.0.2", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "rm -rf dist && tsc -p tsconfig.build.json", diff --git a/packages/i18n/package.json b/packages/i18n/package.json index 6927aae08d1c2..92fa97c42df78 100644 --- a/packages/i18n/package.json +++ b/packages/i18n/package.json @@ -7,7 +7,7 @@ "eslint": "~8.45.0", "jest": "~29.7.0", "tsup": "^6.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "node ./src/index.mjs", diff --git a/packages/instance-status/package.json b/packages/instance-status/package.json index 088cba613d8ed..f15a8feceff59 100644 --- a/packages/instance-status/package.json +++ b/packages/instance-status/package.json @@ -7,7 +7,7 @@ "eslint": "~8.45.0", "mongodb": "^4.17.2", "prettier": "~2.8.8", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/jest-presets/package.json b/packages/jest-presets/package.json index e6c0c9197bced..5fb2e26389a0a 100644 --- a/packages/jest-presets/package.json +++ b/packages/jest-presets/package.json @@ -30,7 +30,7 @@ "@types/uuid": "^9", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.4.5" + "typescript": "~5.5.4" }, "volta": { "extends": "../../package.json" diff --git a/packages/jwt/package.json b/packages/jwt/package.json index a6d989e2c2753..d945bd3a6f9c1 100644 --- a/packages/jwt/package.json +++ b/packages/jwt/package.json @@ -7,7 +7,7 @@ "@types/jest": "~29.5.12", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "rm -rf dist && tsc", diff --git a/packages/livechat/package.json b/packages/livechat/package.json index 9d40643dd4c50..073c2e999e426 100644 --- a/packages/livechat/package.json +++ b/packages/livechat/package.json @@ -85,7 +85,7 @@ "stylelint-order": "^5.0.0", "svg-loader": "^0.0.2", "terser-webpack-plugin": "~4.2.3", - "typescript": "~5.3.3", + "typescript": "~5.5.4", "url-loader": "^4.1.1", "webpack": "^5.89.0", "webpack-bundle-analyzer": "^4.9.1", diff --git a/packages/log-format/package.json b/packages/log-format/package.json index b43a3954a96f4..f6f7c03b6f634 100644 --- a/packages/log-format/package.json +++ b/packages/log-format/package.json @@ -6,7 +6,7 @@ "@types/chalk": "^2.2.0", "@types/ejson": "^2.2.1", "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/logger/package.json b/packages/logger/package.json index aae996f351397..d073ebddbf495 100644 --- a/packages/logger/package.json +++ b/packages/logger/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/message-parser/package.json b/packages/message-parser/package.json index fd7e88dc1d863..78ffd3401ff47 100644 --- a/packages/message-parser/package.json +++ b/packages/message-parser/package.json @@ -68,7 +68,7 @@ "rimraf": "^3.0.2", "ts-loader": "~9.4.2", "typedoc": "~0.24.1", - "typescript": "~5.3.3", + "typescript": "~5.5.4", "webpack": "~5.78.0", "webpack-cli": "~5.0.1" }, diff --git a/packages/mock-providers/package.json b/packages/mock-providers/package.json index 64310f0695cc6..f5fba6c3b74b2 100644 --- a/packages/mock-providers/package.json +++ b/packages/mock-providers/package.json @@ -17,7 +17,7 @@ "@types/use-sync-external-store": "^0.0.5", "eslint": "~8.45.0", "react": "~17.0.2", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "peerDependencies": { "@tanstack/react-query": "*", diff --git a/packages/model-typings/package.json b/packages/model-typings/package.json index f96764fa49af2..13ee8c08b7276 100644 --- a/packages/model-typings/package.json +++ b/packages/model-typings/package.json @@ -6,7 +6,7 @@ "@types/node-rsa": "^1.1.3", "eslint": "~8.45.0", "mongodb": "^4.17.2", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/models/package.json b/packages/models/package.json index 19f1f28438f63..6b0d1c0a6fe7a 100644 --- a/packages/models/package.json +++ b/packages/models/package.json @@ -7,7 +7,7 @@ "@types/jest": "~29.5.12", "eslint": "~8.45.0", "jest": "^29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "dependencies": { "@rocket.chat/model-typings": "workspace:~" diff --git a/packages/node-poplib/package.json b/packages/node-poplib/package.json index a232d6b4c4763..1d0c4c462e46b 100644 --- a/packages/node-poplib/package.json +++ b/packages/node-poplib/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "main": "./src/index.js", "typings": "./dist/index.d.ts" diff --git a/packages/password-policies/package.json b/packages/password-policies/package.json index d53ffa1f52491..a2fef4ae05435 100644 --- a/packages/password-policies/package.json +++ b/packages/password-policies/package.json @@ -7,7 +7,7 @@ "@types/jest": "~29.5.12", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "rm -rf dist && tsc", diff --git a/packages/patch-injection/package.json b/packages/patch-injection/package.json index 99f676bff8312..8dabf2fb3f2a3 100644 --- a/packages/patch-injection/package.json +++ b/packages/patch-injection/package.json @@ -7,7 +7,7 @@ "@types/jest": "~29.5.12", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "rm -rf dist && tsc", diff --git a/packages/peggy-loader/package.json b/packages/peggy-loader/package.json index 5fa014da7f290..f0ac6d915567c 100644 --- a/packages/peggy-loader/package.json +++ b/packages/peggy-loader/package.json @@ -50,7 +50,7 @@ "peggy": "3.0.2", "prettier": "~2.8.7", "rimraf": "^3.0.2", - "typescript": "~5.3.3", + "typescript": "~5.5.4", "webpack": "~5.78.0" }, "volta": { diff --git a/packages/random/package.json b/packages/random/package.json index 72fc8c5c566a6..498e218338d9b 100644 --- a/packages/random/package.json +++ b/packages/random/package.json @@ -23,7 +23,7 @@ "@typescript-eslint/parser": "~5.60.1", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "volta": { "extends": "../../package.json" diff --git a/packages/release-action/package.json b/packages/release-action/package.json index 0d17e4fb42216..e633ef69d06fa 100644 --- a/packages/release-action/package.json +++ b/packages/release-action/package.json @@ -11,7 +11,7 @@ "packageManager": "yarn@3.5.1", "devDependencies": { "@types/node": "^16.18.60", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "dependencies": { "@actions/core": "^1.10.1", diff --git a/packages/release-changelog/package.json b/packages/release-changelog/package.json index 9e48d015b3218..f183d00b550b9 100644 --- a/packages/release-changelog/package.json +++ b/packages/release-changelog/package.json @@ -12,7 +12,7 @@ "@rocket.chat/eslint-config": "workspace:^", "@types/node": "^14.18.63", "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "dependencies": { "dataloader": "^1.4.0", diff --git a/packages/rest-typings/package.json b/packages/rest-typings/package.json index 53bd1d2f5cb2d..b5846800ad690 100644 --- a/packages/rest-typings/package.json +++ b/packages/rest-typings/package.json @@ -7,7 +7,7 @@ "eslint": "~8.45.0", "jest": "~29.7.0", "mongodb": "^4.17.2", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "rm -rf dist && tsc", diff --git a/packages/server-cloud-communication/package.json b/packages/server-cloud-communication/package.json index 8c970687ab8b7..35e67a2c06384 100644 --- a/packages/server-cloud-communication/package.json +++ b/packages/server-cloud-communication/package.json @@ -5,7 +5,7 @@ "devDependencies": { "@rocket.chat/license": "workspace:^", "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "volta": { "extends": "../../package.json" diff --git a/packages/server-fetch/package.json b/packages/server-fetch/package.json index c98b4ba99e549..27f9577585205 100644 --- a/packages/server-fetch/package.json +++ b/packages/server-fetch/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "eslint": "~8.45.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/sha256/package.json b/packages/sha256/package.json index 6d10f5b80d650..fb9e0d0d7f260 100644 --- a/packages/sha256/package.json +++ b/packages/sha256/package.json @@ -22,7 +22,7 @@ "@typescript-eslint/parser": "~5.60.1", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "volta": { "extends": "../../package.json" diff --git a/packages/tools/package.json b/packages/tools/package.json index d1301efb7055e..11dade3ac5c8d 100644 --- a/packages/tools/package.json +++ b/packages/tools/package.json @@ -7,7 +7,7 @@ "@types/jest": "~29.5.12", "eslint": "~8.45.0", "jest": "~29.7.0", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/ui-avatar/package.json b/packages/ui-avatar/package.json index 1c2dc6dabbc4f..d315553b8d833 100644 --- a/packages/ui-avatar/package.json +++ b/packages/ui-avatar/package.json @@ -15,7 +15,7 @@ "eslint-plugin-storybook": "~0.6.15", "eslint-plugin-testing-library": "~5.11.1", "react": "^17.0.2", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "lint": "eslint --ext .js,.jsx,.ts,.tsx .", diff --git a/packages/ui-client/package.json b/packages/ui-client/package.json index f43b2d8622b8a..31492399dee90 100644 --- a/packages/ui-client/package.json +++ b/packages/ui-client/package.json @@ -37,7 +37,7 @@ "react": "^17.0.2", "react-dom": "^17.0.2", "react-hook-form": "~7.45.4", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "scripts": { "build": "rm -rf dist && tsc -p tsconfig.build.json", diff --git a/packages/ui-composer/package.json b/packages/ui-composer/package.json index d854a6ffea869..a051bc16db239 100644 --- a/packages/ui-composer/package.json +++ b/packages/ui-composer/package.json @@ -38,7 +38,7 @@ "react": "~17.0.2", "react-docgen-typescript-plugin": "~1.0.5", "react-dom": "~17.0.2", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "peerDependencies": { "@react-aria/toolbar": "*", diff --git a/packages/ui-contexts/package.json b/packages/ui-contexts/package.json index 513aebd86a302..b2954e61c9ec1 100644 --- a/packages/ui-contexts/package.json +++ b/packages/ui-contexts/package.json @@ -16,7 +16,7 @@ "eslint-plugin-react-hooks": "^4.6.0", "mongodb": "^4.17.2", "react": "~17.0.2", - "typescript": "~5.3.3", + "typescript": "~5.5.4", "use-sync-external-store": "^1.2.0" }, "peerDependencies": { diff --git a/packages/ui-contexts/src/DeviceContext.ts b/packages/ui-contexts/src/DeviceContext.ts index 483f03707f958..5bbda60cfcd56 100644 --- a/packages/ui-contexts/src/DeviceContext.ts +++ b/packages/ui-contexts/src/DeviceContext.ts @@ -6,10 +6,6 @@ export type Device = { type: string; }; -export interface IExperimentalHTMLAudioElement extends HTMLAudioElement { - setSinkId: (sinkId: string) => void; -} - type EnabledDeviceContextValue = { enabled: true; availableAudioOutputDevices: Device[]; @@ -18,7 +14,7 @@ type EnabledDeviceContextValue = { selectedAudioOutputDevice?: Device; selectedAudioInputDevice?: Device; // selectedVideoInputDevice?: Device; - setAudioOutputDevice: (data: { outputDevice: Device; HTMLAudioElement: IExperimentalHTMLAudioElement }) => void; + setAudioOutputDevice: (data: { outputDevice: Device; HTMLAudioElement: HTMLAudioElement }) => void; setAudioInputDevice: (device: Device) => void; // setVideoInputDevice: (device: Device) => void; }; diff --git a/packages/ui-contexts/src/hooks/useEndpoint.ts b/packages/ui-contexts/src/hooks/useEndpoint.ts index a0b7c977f2c61..3d29917c63e2d 100644 --- a/packages/ui-contexts/src/hooks/useEndpoint.ts +++ b/packages/ui-contexts/src/hooks/useEndpoint.ts @@ -14,7 +14,7 @@ export type EndpointFunction( method: TMethod, pathPattern: TPathPattern, - ...[keys]: undefined extends UrlParams ? [keys?: UrlParams] : [keys: UrlParams] + ...[keys]: NoInfer ? [keys?: UrlParams] : [keys: UrlParams]> ): EndpointFunction { const { callEndpoint } = useContext(ServerContext); const keysRef = useRef(keys); diff --git a/packages/ui-contexts/src/hooks/useSetOutputMediaDevice.ts b/packages/ui-contexts/src/hooks/useSetOutputMediaDevice.ts index 7a68d7b10e0d4..c3d6b94258767 100644 --- a/packages/ui-contexts/src/hooks/useSetOutputMediaDevice.ts +++ b/packages/ui-contexts/src/hooks/useSetOutputMediaDevice.ts @@ -1,17 +1,11 @@ import { useContext } from 'react'; -import type { Device, IExperimentalHTMLAudioElement } from '../DeviceContext'; +import type { Device } from '../DeviceContext'; import { DeviceContext, isDeviceContextEnabled } from '../DeviceContext'; // This allows different places to set the output device by providing a HTMLAudioElement -type setOutputMediaDevice = ({ - outputDevice, - HTMLAudioElement, -}: { - outputDevice: Device; - HTMLAudioElement: IExperimentalHTMLAudioElement; -}) => void; +type setOutputMediaDevice = ({ outputDevice, HTMLAudioElement }: { outputDevice: Device; HTMLAudioElement: HTMLAudioElement }) => void; export const useSetOutputMediaDevice = (): setOutputMediaDevice => { const context = useContext(DeviceContext); diff --git a/packages/ui-contexts/src/index.ts b/packages/ui-contexts/src/index.ts index e021eb840aa0d..313710bbfd4ef 100644 --- a/packages/ui-contexts/src/index.ts +++ b/packages/ui-contexts/src/index.ts @@ -14,7 +14,7 @@ export { ToastMessagesContext, ToastMessagesContextValue } from './ToastMessages export { TooltipContext, TooltipContextValue } from './TooltipContext'; export { TranslationContext, TranslationContextValue } from './TranslationContext'; export { UserContext, UserContextValue } from './UserContext'; -export { DeviceContext, Device, IExperimentalHTMLAudioElement, DeviceContextValue } from './DeviceContext'; +export { DeviceContext, Device, DeviceContextValue } from './DeviceContext'; export { ActionManagerContext, IActionManager } from './ActionManagerContext'; export { useAbsoluteUrl } from './hooks/useAbsoluteUrl'; diff --git a/packages/ui-kit/package.json b/packages/ui-kit/package.json index c7e8159d457d7..ae42ec71b2a04 100644 --- a/packages/ui-kit/package.json +++ b/packages/ui-kit/package.json @@ -52,11 +52,11 @@ "ts-jest": "~29.1.1", "ts-loader": "~9.4.2", "ts-node": "~10.9.1", - "ts-patch": "~3.0.2", - "typescript": "~5.3.3" + "ts-patch": "~3.2.1", + "typescript": "~5.5.4" }, "dependencies": { - "typia": "~5.3.3" + "typia": "~6.9.0" }, "peerDependencies": { "@rocket.chat/icons": "*" diff --git a/packages/ui-video-conf/package.json b/packages/ui-video-conf/package.json index 5e7d114a35762..befa3514509f3 100644 --- a/packages/ui-video-conf/package.json +++ b/packages/ui-video-conf/package.json @@ -32,7 +32,7 @@ "jest": "~29.7.0", "jest-axe": "~9.0.0", "react-docgen-typescript-plugin": "~1.0.5", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "peerDependencies": { "@rocket.chat/css-in-js": "*", diff --git a/packages/uikit-playground/package.json b/packages/uikit-playground/package.json index f46f139a66f45..e29be5287b65e 100644 --- a/packages/uikit-playground/package.json +++ b/packages/uikit-playground/package.json @@ -50,7 +50,7 @@ "eslint": "~8.45.0", "eslint-plugin-react-hooks": "^4.6.0", "eslint-plugin-react-refresh": "^0.4.4", - "typescript": "~5.3.3", + "typescript": "~5.5.4", "vite": "^4.3.9" }, "volta": { diff --git a/packages/web-ui-registration/package.json b/packages/web-ui-registration/package.json index ba3dc31423a62..4a9b4ac82a9cf 100644 --- a/packages/web-ui-registration/package.json +++ b/packages/web-ui-registration/package.json @@ -42,7 +42,7 @@ "react-hook-form": "~7.45.4", "react-i18next": "~13.2.2", "storybook-dark-mode": "~3.0.1", - "typescript": "~5.3.3" + "typescript": "~5.5.4" }, "peerDependencies": { "@rocket.chat/layout": "*", diff --git a/yarn.lock b/yarn.lock index f2e9022958487..7ef356f546464 100644 --- a/yarn.lock +++ b/yarn.lock @@ -8433,7 +8433,7 @@ __metadata: pino: ^8.15.0 polka: ^0.5.2 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 uuid: ^9.0.1 languageName: unknown linkType: soft @@ -8443,7 +8443,7 @@ __metadata: resolution: "@rocket.chat/account-utils@workspace:packages/account-utils" dependencies: eslint: ~8.45.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8459,7 +8459,7 @@ __metadata: human-interval: ^2.0.1 moment-timezone: ~0.5.43 mongodb: ^4.17.2 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8479,7 +8479,7 @@ __metadata: query-string: ^7.1.3 split-on-first: ^3.0.0 strict-uri-encode: ^2.0.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8513,7 +8513,7 @@ __metadata: "@rocket.chat/core-typings": "workspace:^" "@rocket.chat/model-typings": "workspace:^" eslint: ~8.45.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8545,7 +8545,7 @@ __metadata: pino: ^8.15.0 polka: ^0.5.2 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8561,7 +8561,7 @@ __metadata: "@typescript-eslint/parser": ~5.60.1 eslint: ~8.45.0 jest: ~29.7.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8571,7 +8571,7 @@ __metadata: dependencies: cheerio: 1.0.0-rc.10 eslint: ~8.45.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8601,7 +8601,7 @@ __metadata: jest: ~29.7.0 mongodb: ^4.17.2 prettier: ~2.8.8 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8617,7 +8617,7 @@ __metadata: eslint: ~8.45.0 mongodb: ^4.17.2 prettier: ~2.8.8 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8631,7 +8631,7 @@ __metadata: "@rocket.chat/random": "workspace:^" eslint: ~8.45.0 mongodb: ^4.17.2 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8670,7 +8670,7 @@ __metadata: eslint: ~8.45.0 jest: ~29.7.0 jest-websocket-mock: ~2.5.0 - typescript: ~5.3.3 + typescript: ~5.5.4 ws: ^8.13.0 peerDependencies: "@rocket.chat/emitter": "*" @@ -8718,7 +8718,7 @@ __metadata: polka: ^0.5.2 sharp: ^0.32.6 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 underscore: ^1.13.6 uuid: ^7.0.3 ws: ^8.8.1 @@ -8758,7 +8758,7 @@ __metadata: resolution: "@rocket.chat/favicon@workspace:packages/favicon" dependencies: eslint: ~8.45.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -8923,7 +8923,7 @@ __metadata: rimraf: ^3.0.2 storybook-dark-mode: ~3.0.1 tslib: ^2.5.3 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@rocket.chat/apps-engine": "*" "@rocket.chat/eslint-config": 0.7.0 @@ -9012,7 +9012,7 @@ __metadata: react-docgen-typescript-plugin: ~1.0.5 react-dom: ~17.0.2 react-error-boundary: ^3.1.4 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@rocket.chat/core-typings": "workspace:^" "@rocket.chat/css-in-js": "*" @@ -9035,7 +9035,7 @@ __metadata: eslint: ~8.45.0 jest: ~29.7.0 tsup: ^6.7.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9055,7 +9055,7 @@ __metadata: eslint: ~8.45.0 mongodb: ^4.17.2 prettier: ~2.8.8 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9077,7 +9077,7 @@ __metadata: jest-axe: ~9.0.0 jest-environment-jsdom: ~29.7.0 jest-environment-node: ~29.7.0 - typescript: ~5.4.5 + typescript: ~5.5.4 uuid: ~9.0.1 languageName: unknown linkType: soft @@ -9091,7 +9091,7 @@ __metadata: eslint: ~8.45.0 jest: ~29.7.0 jose: ^4.14.4 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9122,7 +9122,7 @@ __metadata: eslint: ~8.45.0 jest: ~29.7.0 jest-websocket-mock: ~2.5.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9210,7 +9210,7 @@ __metadata: stylelint-order: ^5.0.0 svg-loader: ^0.0.2 terser-webpack-plugin: ~4.2.3 - typescript: ~5.3.3 + typescript: ~5.5.4 url-loader: ^4.1.1 webpack: ^5.89.0 webpack-bundle-analyzer: ^4.9.1 @@ -9232,7 +9232,7 @@ __metadata: chalk: ^4.0.0 ejson: ^2.2.3 eslint: ~8.45.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9243,7 +9243,7 @@ __metadata: "@rocket.chat/emitter": ~0.31.25 eslint: ~8.45.0 pino: ^8.15.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9292,7 +9292,7 @@ __metadata: tldts: ~5.7.112 ts-loader: ~9.4.2 typedoc: ~0.24.1 - typescript: ~5.3.3 + typescript: ~5.5.4 webpack: ~5.78.0 webpack-cli: ~5.0.1 languageName: unknown @@ -9665,8 +9665,8 @@ __metadata: turndown: ^7.1.2 twilio: ^3.76.1 twit: ^2.2.11 - typescript: ~5.3.3 - typia: ^5.3.3 + typescript: ~5.5.4 + typia: ~6.9.0 ua-parser-js: ^1.0.37 underscore: ^1.13.6 universal-perf-hooks: ^1.0.1 @@ -9698,7 +9698,7 @@ __metadata: i18next: ~23.4.9 react: ~17.0.2 react-i18next: ~13.2.2 - typescript: ~5.3.3 + typescript: ~5.5.4 use-sync-external-store: ~1.2.2 peerDependencies: "@tanstack/react-query": "*" @@ -9714,7 +9714,7 @@ __metadata: "@types/node-rsa": ^1.1.3 eslint: ~8.45.0 mongodb: ^4.17.2 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9727,7 +9727,7 @@ __metadata: "@types/jest": ~29.5.12 eslint: ~8.45.0 jest: ^29.7.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9770,7 +9770,7 @@ __metadata: mongo-message-queue: ^1.0.0 mongodb: ^4.17.2 pino: ^8.15.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9808,7 +9808,7 @@ __metadata: pino: ^8.15.0 polka: ^0.5.2 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9841,7 +9841,7 @@ __metadata: "@types/jest": ~29.5.12 eslint: ~8.45.0 jest: ~29.7.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9853,7 +9853,7 @@ __metadata: "@types/jest": ~29.5.12 eslint: ~8.45.0 jest: ~29.7.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9880,7 +9880,7 @@ __metadata: moment-timezone: ^0.5.43 react: ~18.3.1 react-dom: ~18.3.1 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9896,7 +9896,7 @@ __metadata: peggy: 3.0.2 prettier: ~2.8.7 rimraf: ^3.0.2 - typescript: ~5.3.3 + typescript: ~5.5.4 webpack: ~5.78.0 peerDependencies: peggy: "*" @@ -9909,7 +9909,7 @@ __metadata: resolution: "@rocket.chat/poplib@workspace:packages/node-poplib" dependencies: eslint: ~8.45.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9941,7 +9941,7 @@ __metadata: pino: ^8.15.0 polka: ^0.5.2 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -9963,7 +9963,7 @@ __metadata: eslint: ~8.45.0 jest: ~29.7.0 mongodb: ^4.17.2 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10008,7 +10008,7 @@ __metadata: pino: ^8.15.0 polka: ^0.5.2 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10024,7 +10024,7 @@ __metadata: "@typescript-eslint/parser": ~5.60.1 eslint: ~8.45.0 jest: ~29.7.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10043,7 +10043,7 @@ __metadata: remark-parse: 9.0.0 remark-stringify: 9.0.1 semver: ^7.5.2 - typescript: ~5.3.3 + typescript: ~5.5.4 unified: 9.2.2 languageName: unknown linkType: soft @@ -10058,7 +10058,7 @@ __metadata: dataloader: ^1.4.0 eslint: ~8.45.0 node-fetch: ^2 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10077,7 +10077,7 @@ __metadata: eslint: ~8.45.0 jest: ~29.7.0 mongodb: ^4.17.2 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10100,7 +10100,7 @@ __metadata: dependencies: "@rocket.chat/license": "workspace:^" eslint: ~8.45.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10114,7 +10114,7 @@ __metadata: https-proxy-agent: ^5.0.1 node-fetch: 2.3.0 proxy-from-env: ^1.1.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10130,7 +10130,7 @@ __metadata: "@typescript-eslint/parser": ~5.60.1 eslint: ~8.45.0 jest: ~29.7.0 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10164,7 +10164,7 @@ __metadata: pino: ^8.15.0 polka: ^0.5.2 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10204,7 +10204,7 @@ __metadata: eslint: ~8.45.0 jest: ~29.7.0 moment-timezone: ^0.5.43 - typescript: ~5.3.3 + typescript: ~5.5.4 languageName: unknown linkType: soft @@ -10224,7 +10224,7 @@ __metadata: eslint-plugin-storybook: ~0.6.15 eslint-plugin-testing-library: ~5.11.1 react: ^17.0.2 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@rocket.chat/fuselage": "*" "@rocket.chat/ui-contexts": 9.0.0 @@ -10270,7 +10270,7 @@ __metadata: react: ^17.0.2 react-dom: ^17.0.2 react-hook-form: ~7.45.4 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@react-aria/toolbar": "*" "@rocket.chat/css-in-js": "*" @@ -10308,7 +10308,7 @@ __metadata: react: ~17.0.2 react-docgen-typescript-plugin: ~1.0.5 react-dom: ~17.0.2 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@react-aria/toolbar": "*" "@rocket.chat/fuselage": "*" @@ -10336,7 +10336,7 @@ __metadata: eslint-plugin-react-hooks: ^4.6.0 mongodb: ^4.17.2 react: ~17.0.2 - typescript: ~5.3.3 + typescript: ~5.5.4 use-sync-external-store: ^1.2.0 peerDependencies: "@rocket.chat/core-typings": "workspace:^" @@ -10371,9 +10371,9 @@ __metadata: ts-jest: ~29.1.1 ts-loader: ~9.4.2 ts-node: ~10.9.1 - ts-patch: ~3.0.2 - typescript: ~5.3.3 - typia: ~5.3.3 + ts-patch: ~3.2.1 + typescript: ~5.5.4 + typia: ~6.9.0 peerDependencies: "@rocket.chat/icons": "*" languageName: unknown @@ -10396,7 +10396,7 @@ __metadata: eslint-plugin-testing-library: ^5.11.1 react: ~17.0.2 react-docgen-typescript-plugin: ~1.0.5 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@rocket.chat/css-in-js": "*" "@rocket.chat/fuselage": "*" @@ -10440,7 +10440,7 @@ __metadata: jest: ~29.7.0 jest-axe: ~9.0.0 react-docgen-typescript-plugin: ~1.0.5 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@rocket.chat/css-in-js": "*" "@rocket.chat/fuselage": "*" @@ -10495,7 +10495,7 @@ __metadata: react-split-pane: ^0.1.92 react-virtuoso: ^4.7.1 reactflow: ^11.7.2 - typescript: ~5.3.3 + typescript: ~5.5.4 use-subscription: ^1.8.0 vite: ^4.3.9 languageName: unknown @@ -10531,7 +10531,7 @@ __metadata: react-hook-form: ~7.45.4 react-i18next: ~13.2.2 storybook-dark-mode: ~3.0.1 - typescript: ~5.3.3 + typescript: ~5.5.4 peerDependencies: "@rocket.chat/layout": "*" "@rocket.chat/tools": 0.2.2 @@ -10543,6 +10543,13 @@ __metadata: languageName: unknown linkType: soft +"@samchon/openapi@npm:^0.4.6": + version: 0.4.9 + resolution: "@samchon/openapi@npm:0.4.9" + checksum: a6fd35db27ebf3223c4793bd9a6669fc0e48ccbe522fa8eb26519073b897fb774cd652777e8d7d414bc19bf47ae03be227dfc2b65e2e1a5869c9723c5adad2e0 + languageName: node + linkType: hard + "@selderee/plugin-htmlparser2@npm:^0.6.0": version: 0.6.0 resolution: "@selderee/plugin-htmlparser2@npm:0.6.0" @@ -36734,7 +36741,7 @@ __metadata: sodium-native: ^3.3.0 sodium-plus: ^0.9.0 ts-node: ^10.9.1 - typescript: ~5.3.3 + typescript: ~5.5.4 uuid: ^8.3.2 ws: ^8.8.1 languageName: unknown @@ -37200,7 +37207,7 @@ __metadata: languageName: node linkType: hard -"semver@npm:^7.2, semver@npm:^7.2.1, semver@npm:^7.3.2, semver@npm:^7.3.4, semver@npm:^7.3.5, semver@npm:^7.3.7, semver@npm:^7.3.8, semver@npm:^7.5.2, semver@npm:^7.5.3, semver@npm:^7.5.4": +"semver@npm:^7.2, semver@npm:^7.2.1, semver@npm:^7.3.2, semver@npm:^7.3.4, semver@npm:^7.3.5, semver@npm:^7.3.7, semver@npm:^7.5.2, semver@npm:^7.5.3, semver@npm:^7.5.4": version: 7.5.4 resolution: "semver@npm:7.5.4" dependencies: @@ -40047,20 +40054,20 @@ __metadata: languageName: node linkType: hard -"ts-patch@npm:~3.0.2": - version: 3.0.2 - resolution: "ts-patch@npm:3.0.2" +"ts-patch@npm:~3.2.1": + version: 3.2.1 + resolution: "ts-patch@npm:3.2.1" dependencies: chalk: ^4.1.2 global-prefix: ^3.0.0 minimist: ^1.2.8 resolve: ^1.22.2 - semver: ^7.3.8 + semver: ^7.5.4 strip-ansi: ^6.0.1 bin: ts-patch: bin/ts-patch.js tspc: bin/tspc.js - checksum: 09cdc54bf517b11d4b0de64515e9a0d7e71e238d6065b3c02a04280dc2683143cd810a9065046228571af0865a7d876a4a852ff9a909cb2cae8fe33b41e4eb81 + checksum: 8da4472dcd67b561a6299b54e30ab96181598edb90a97bc8dbe0066b28d706ec7402fee73496d25a281e2c4c94cb8e86d3b1592b1ca7591ea0b6cb48617ed19c languageName: node linkType: hard @@ -40544,75 +40551,57 @@ __metadata: languageName: node linkType: hard -"typescript@npm:~5.3.3": - version: 5.3.3 - resolution: "typescript@npm:5.3.3" - bin: - tsc: bin/tsc - tsserver: bin/tsserver - checksum: 2007ccb6e51bbbf6fde0a78099efe04dc1c3dfbdff04ca3b6a8bc717991862b39fd6126c0c3ebf2d2d98ac5e960bcaa873826bb2bb241f14277034148f41f6a2 - languageName: node - linkType: hard - -"typescript@npm:~5.4.5": - version: 5.4.5 - resolution: "typescript@npm:5.4.5" - bin: - tsc: bin/tsc - tsserver: bin/tsserver - checksum: 53c879c6fa1e3bcb194b274d4501ba1985894b2c2692fa079db03c5a5a7140587a1e04e1ba03184605d35f439b40192d9e138eb3279ca8eee313c081c8bcd9b0 - languageName: node - linkType: hard - -"typescript@patch:typescript@~5.3.3#~builtin": - version: 5.3.3 - resolution: "typescript@patch:typescript@npm%3A5.3.3#~builtin::version=5.3.3&hash=85af82" +"typescript@npm:~5.5.4": + version: 5.5.4 + resolution: "typescript@npm:5.5.4" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: f61375590b3162599f0f0d5b8737877ac0a7bc52761dbb585d67e7b8753a3a4c42d9a554c4cc929f591ffcf3a2b0602f65ae3ce74714fd5652623a816862b610 + checksum: b309040f3a1cd91c68a5a58af6b9fdd4e849b8c42d837b2c2e73f9a4f96a98c4f1ed398a9aab576ee0a4748f5690cf594e6b99dbe61de7839da748c41e6d6ca8 languageName: node linkType: hard -"typescript@patch:typescript@~5.4.5#~builtin": - version: 5.4.5 - resolution: "typescript@patch:typescript@npm%3A5.4.5#~builtin::version=5.4.5&hash=85af82" +"typescript@patch:typescript@~5.5.4#~builtin": + version: 5.5.4 + resolution: "typescript@patch:typescript@npm%3A5.5.4#~builtin::version=5.5.4&hash=85af82" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: 2373c693f3b328f3b2387c3efafe6d257b057a142f9a79291854b14ff4d5367d3d730810aee981726b677ae0fd8329b23309da3b6aaab8263dbdccf1da07a3ba + checksum: fc52962f31a5bcb716d4213bef516885e4f01f30cea797a831205fc9ef12b405a40561c40eae3127ab85ba1548e7df49df2bcdee6b84a94bfbe3a0d7eff16b14 languageName: node linkType: hard -"typia@npm:5.3.3, typia@npm:^5.3.3": - version: 5.3.3 - resolution: "typia@npm:5.3.3" +"typia@npm:6.9.0": + version: 6.9.0 + resolution: "typia@npm:6.9.0" dependencies: + "@samchon/openapi": ^0.4.6 commander: ^10.0.0 comment-json: ^4.2.3 inquirer: ^8.2.5 randexp: ^0.5.3 peerDependencies: - typescript: ">=4.8.0 <5.4.0" + typescript: ">=4.8.0 <5.6.0" bin: typia: lib/executable/typia.js - checksum: 6e6c9f4c1382deda6ee91fb42f0adbfa57c5b73541a2e411474108d1deac9dd2f590fbbe48399c0357064a6298b5ab17324aa521195cf8e470057171ce868a64 + checksum: 1d5ab0d331ff29b84914f5c8c5655fe3b1d17fae45ac3a76d30690de8414e8c45a27c189662896730c3211a436373e8c2eb3fc55d2eeb6ac8d15a1f50218a2e9 languageName: node linkType: hard -"typia@patch:typia@npm%3A5.3.3#./.yarn/patches/typia-npm-5.3.3-21d3e18463.patch::locator=rocket.chat%40workspace%3A.": - version: 5.3.3 - resolution: "typia@patch:typia@npm%3A5.3.3#./.yarn/patches/typia-npm-5.3.3-21d3e18463.patch::version=5.3.3&hash=777cd5&locator=rocket.chat%40workspace%3A." +"typia@patch:typia@npm%3A6.9.0#./.yarn/patches/typia-npm-6.9.0-2fd4d85f25.patch::locator=rocket.chat%40workspace%3A.": + version: 6.9.0 + resolution: "typia@patch:typia@npm%3A6.9.0#./.yarn/patches/typia-npm-6.9.0-2fd4d85f25.patch::version=6.9.0&hash=71fcee&locator=rocket.chat%40workspace%3A." dependencies: + "@samchon/openapi": ^0.4.6 commander: ^10.0.0 comment-json: ^4.2.3 inquirer: ^8.2.5 randexp: ^0.5.3 peerDependencies: - typescript: ">=4.8.0 <5.4.0" + typescript: ">=4.8.0 <5.6.0" bin: typia: lib/executable/typia.js - checksum: 256a670f6d3265135090a493c9519cd97466444188766ce9f4e434d2bfe29ec88c3a4ac3ac39938921e116873694ac526136957cbed5710109525d4d0d2425da + checksum: d87f150a526959f92ac9bafe7ad88121e69a2807c7aeb01a625cb845e0614fb09c54bbdbd68d0c90bce37072c2da5e153daa2ccd1f5ff7ca92eca4b5edf9e8a9 languageName: node linkType: hard From 037128cc55d9f3293f6f73adcbedd74f41125f8a Mon Sep 17 00:00:00 2001 From: Douglas Fabris Date: Mon, 2 Sep 2024 13:00:47 -0300 Subject: [PATCH 4/4] test: Add some unit tests for `useRetentionPolicy` (#33196) --- .../room/hooks/useRetentionPolicy.spec.ts | 87 +++++++++++++++++++ apps/meteor/tests/mocks/data.ts | 2 +- 2 files changed, 88 insertions(+), 1 deletion(-) create mode 100644 apps/meteor/client/views/room/hooks/useRetentionPolicy.spec.ts diff --git a/apps/meteor/client/views/room/hooks/useRetentionPolicy.spec.ts b/apps/meteor/client/views/room/hooks/useRetentionPolicy.spec.ts new file mode 100644 index 0000000000000..9b99d6e4d781f --- /dev/null +++ b/apps/meteor/client/views/room/hooks/useRetentionPolicy.spec.ts @@ -0,0 +1,87 @@ +import { mockAppRoot } from '@rocket.chat/mock-providers'; +import { renderHook } from '@testing-library/react'; + +import { createFakeRoom } from '../../../../tests/mocks/data'; +import { useRetentionPolicy } from './useRetentionPolicy'; + +const getGlobalSettings = ({ + enabled = false, + filesOnly = false, + doNotPrunePinned = false, + ignoreThreads = false, + appliesToChannels = false, + appliesToGroups = false, + appliesToDMs = false, +}) => { + return mockAppRoot() + .withSetting('RetentionPolicy_Enabled', enabled) + .withSetting('RetentionPolicy_FilesOnly', filesOnly) + .withSetting('RetentionPolicy_DoNotPrunePinned', doNotPrunePinned) + .withSetting('RetentionPolicy_DoNotPruneThreads', ignoreThreads) + .withSetting('RetentionPolicy_AppliesToChannels', appliesToChannels) + .withSetting('RetentionPolicy_AppliesToGroups', appliesToGroups) + .withSetting('RetentionPolicy_AppliesToDMs', appliesToDMs); +}; + +const defaultValue = { + enabled: false, + isActive: false, + filesOnly: false, + excludePinned: false, + ignoreThreads: false, +}; + +const roomTypeConfig = { + c: { appliesToChannels: true }, + p: { appliesToGroups: true }, + d: { appliesToDMs: true }, +}; + +const CHANNELS_TYPE = 'c'; + +it('should return the default value if global retention is not enabled', async () => { + const fakeRoom = createFakeRoom({ t: CHANNELS_TYPE }); + + const { result } = renderHook(() => useRetentionPolicy(fakeRoom), { + legacyRoot: true, + wrapper: getGlobalSettings({}).build(), + }); + + expect(result.current).toEqual(expect.objectContaining(defaultValue)); +}); + +it('should return enabled true if global retention is enabled', async () => { + const fakeRoom = createFakeRoom({ t: CHANNELS_TYPE }); + + const { result } = renderHook(() => useRetentionPolicy(fakeRoom), { + legacyRoot: true, + wrapper: getGlobalSettings({ enabled: true }).build(), + }); + + expect(result.current).toEqual(expect.objectContaining({ ...defaultValue, enabled: true })); +}); + +it('should return enabled and active true global retention is active for rooms of the type', async () => { + const fakeRoom = createFakeRoom({ t: CHANNELS_TYPE }); + + const { result } = renderHook(() => useRetentionPolicy(fakeRoom), { + legacyRoot: true, + wrapper: getGlobalSettings({ enabled: true, ...roomTypeConfig[CHANNELS_TYPE] }).build(), + }); + + expect(result.current).toEqual(expect.objectContaining({ ...defaultValue, enabled: true, isActive: true })); +}); + +it.failing( + 'should isActive be false if global retention is active for rooms of the type and room has retention.enabled false', + async () => { + const fakeRoom = createFakeRoom({ t: CHANNELS_TYPE, retention: { enabled: false } }); + + const { result } = renderHook(() => useRetentionPolicy(fakeRoom), { + legacyRoot: true, + wrapper: getGlobalSettings({ enabled: true, ...roomTypeConfig[CHANNELS_TYPE] }).build(), + }); + + expect(result.current?.isActive).toBe(false); + }, +); diff --git a/apps/meteor/tests/mocks/data.ts b/apps/meteor/tests/mocks/data.ts index 14f03a6bd9ab6..fd6a0ce911230 100644 --- a/apps/meteor/tests/mocks/data.ts +++ b/apps/meteor/tests/mocks/data.ts @@ -21,7 +21,7 @@ export function createFakeUser(overrides?: Partial): IUser { }; } -export const createFakeRoom = (overrides?: Partial): IRoom => ({ +export const createFakeRoom = (overrides?: Partial): IRoom => ({ _id: faker.database.mongodbObjectId(), _updatedAt: faker.date.recent(), t: faker.helpers.arrayElement(['c', 'p', 'd']),