diff --git a/apps/meteor/app/api/server/v1/videoConference.ts b/apps/meteor/app/api/server/v1/videoConference.ts index f471fcaebe404..cefa7ffd85d86 100644 --- a/apps/meteor/app/api/server/v1/videoConference.ts +++ b/apps/meteor/app/api/server/v1/videoConference.ts @@ -114,7 +114,7 @@ API.v1.addRoute( API.v1.addRoute( 'video-conference.info', - { authRequired: true, validateParams: isVideoConfInfoProps, rateLimiterOptions: { numRequestsAllowed: 3, intervalTimeInMS: 1000 } }, + { authRequired: true, validateParams: isVideoConfInfoProps, rateLimiterOptions: { numRequestsAllowed: 15, intervalTimeInMS: 3000 } }, { async get() { const { callId } = this.queryParams; diff --git a/apps/meteor/client/views/blocks/MessageBlock.js b/apps/meteor/client/views/blocks/MessageBlock.js index 1b9c194350ca7..965a0d9b3957a 100644 --- a/apps/meteor/client/views/blocks/MessageBlock.js +++ b/apps/meteor/client/views/blocks/MessageBlock.js @@ -1,12 +1,21 @@ import { UIKitIncomingInteractionContainerType } from '@rocket.chat/apps-engine/definition/uikit/UIKitIncomingInteractionContainer'; +import { useMutableCallback } from '@rocket.chat/fuselage-hooks'; import { UiKitMessage, UiKitComponent, kitContext, messageParser } from '@rocket.chat/fuselage-ui-kit'; import React from 'react'; import * as ActionManager from '../../../app/ui-message/client/ActionManager'; import { useBlockRendered } from '../../components/message/hooks/useBlockRendered'; -import { useVideoConfJoinCall, useVideoConfSetPreferences } from '../../contexts/VideoConfContext'; +import { + useVideoConfJoinCall, + useVideoConfSetPreferences, + useVideoConfIsCalling, + useVideoConfIsRinging, + useVideoConfDispatchOutgoing, +} from '../../contexts/VideoConfContext'; +import { VideoConfManager } from '../../lib/VideoConfManager'; import { renderMessageBody } from '../../lib/utils/renderMessageBody'; import './textParsers'; +import { useVideoConfWarning } from '../room/contextualBar/VideoConference/useVideoConfWarning'; // TODO: move this to fuselage-ui-kit itself const mrkdwn = ({ text } = {}) => text && ; @@ -16,14 +25,36 @@ function MessageBlock({ mid: _mid, rid, blocks, appId }) { const { ref, className } = useBlockRendered(); const joinCall = useVideoConfJoinCall(); const setPreferences = useVideoConfSetPreferences(); + const isCalling = useVideoConfIsCalling(); + const isRinging = useVideoConfIsRinging(); + const dispatchWarning = useVideoConfWarning(); + const dispatchPopup = useVideoConfDispatchOutgoing(); + + const handleOpenVideoConf = useMutableCallback(async (rid) => { + if (isCalling || isRinging) { + return; + } + + try { + await VideoConfManager.loadCapabilities(); + dispatchPopup({ rid }); + } catch (error) { + dispatchWarning(error.error); + } + }); const context = { action: ({ actionId, value, blockId, mid = _mid, appId }, event) => { - if (appId === 'videoconf-core' && actionId === 'join') { + if (appId === 'videoconf-core') { event.preventDefault(); setPreferences({ mic: true, cam: false }); - joinCall(blockId); - return; + if (actionId === 'join') { + return joinCall(blockId); + } + + if (actionId === 'callBack') { + return handleOpenVideoConf(blockId); + } } ActionManager.triggerBlockAction({ diff --git a/apps/meteor/client/views/room/contextualBar/VideoConference/VideoConfList/VideoConfListItem.tsx b/apps/meteor/client/views/room/contextualBar/VideoConference/VideoConfList/VideoConfListItem.tsx index d96e1ef8452fe..692f46d9930a1 100644 --- a/apps/meteor/client/views/room/contextualBar/VideoConference/VideoConfList/VideoConfListItem.tsx +++ b/apps/meteor/client/views/room/contextualBar/VideoConference/VideoConfList/VideoConfListItem.tsx @@ -88,7 +88,7 @@ const VideoConfListItem = ({ {joinedUsers.length > VIDEOCONF_STACK_MAX_USERS - ? t('__usersCount__members_joined', { usersCount: joinedUsers.length - VIDEOCONF_STACK_MAX_USERS }) + ? t('__usersCount__member_joined', { usersCount: joinedUsers.length - VIDEOCONF_STACK_MAX_USERS }) : t('joined')} diff --git a/apps/meteor/package.json b/apps/meteor/package.json index 0a2cb03c5357d..9bddfae313235 100644 --- a/apps/meteor/package.json +++ b/apps/meteor/package.json @@ -61,11 +61,11 @@ "email": "support@rocket.chat" }, "devDependencies": { - "@babel/core": "^7.18.9", + "@babel/core": "^7.18.13", "@babel/eslint-parser": "^7.18.9", "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", "@babel/plugin-proposal-optional-chaining": "^7.18.9", - "@babel/preset-env": "^7.18.9", + "@babel/preset-env": "^7.18.10", "@babel/preset-react": "^7.18.6", "@babel/register": "^7.18.9", "@faker-js/faker": "^6.3.1", @@ -127,7 +127,7 @@ "@types/prometheus-gc-stats": "^0.6.2", "@types/proxyquire": "^1.3.28", "@types/psl": "^1.1.0", - "@types/react": "~17.0.47", + "@types/react": "~17.0.48", "@types/react-dom": "~17.0.17", "@types/rewire": "^2.5.28", "@types/sanitize-html": "^2", @@ -156,7 +156,7 @@ "chai-spies": "^1.0.0", "cross-env": "^7.0.3", "emojione-assets": "^4.5.0", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "eslint-config-prettier": "^8.5.0", "eslint-plugin-import": "^2.26.0", "eslint-plugin-playwright": "^0.11.1", @@ -205,7 +205,7 @@ "@react-aria/color": "^3.0.0-beta.15", "@rocket.chat/agenda": "workspace:^", "@rocket.chat/api-client": "workspace:^", - "@rocket.chat/apps-engine": "latest", + "@rocket.chat/apps-engine": "1.36.0-videoconf", "@rocket.chat/cas-validate": "workspace:^", "@rocket.chat/core-typings": "workspace:^", "@rocket.chat/css-in-js": "0.31.21", @@ -214,11 +214,11 @@ "@rocket.chat/forked-matrix-appservice-bridge": "^4.0.1", "@rocket.chat/forked-matrix-bot-sdk": "^0.6.0-beta.2", "@rocket.chat/fuselage": "next", - "@rocket.chat/fuselage-hooks": "0.31.21", - "@rocket.chat/fuselage-polyfills": "0.31.21", - "@rocket.chat/fuselage-toastbar": "0.31.21", - "@rocket.chat/fuselage-tokens": "0.31.21", - "@rocket.chat/fuselage-ui-kit": "0.31.21", + "@rocket.chat/fuselage-hooks": "next", + "@rocket.chat/fuselage-polyfills": "next", + "@rocket.chat/fuselage-toastbar": "next", + "@rocket.chat/fuselage-tokens": "next", + "@rocket.chat/fuselage-ui-kit": "workspace:^", "@rocket.chat/gazzodown": "workspace:^", "@rocket.chat/icons": "0.31.21", "@rocket.chat/layout": "next", @@ -241,7 +241,7 @@ "@rocket.chat/ui-video-conf": "workspace:^", "@rocket.chat/web-ui-registration": "workspace:^", "@slack/rtm-api": "^6.0.0", - "@tanstack/react-query": "^4.0.10", + "@tanstack/react-query": "^4.16.1", "@types/cookie": "^0.5.1", "@types/katex": "^0.14.0", "@types/lodash": "^4.14.182", diff --git a/apps/meteor/packages/rocketchat-i18n/i18n/en.i18n.json b/apps/meteor/packages/rocketchat-i18n/i18n/en.i18n.json index dbc5f322e4fa5..53e0a6a8216fc 100644 --- a/apps/meteor/packages/rocketchat-i18n/i18n/en.i18n.json +++ b/apps/meteor/packages/rocketchat-i18n/i18n/en.i18n.json @@ -5,7 +5,8 @@ "__count__empty_rooms_will_be_removed_automatically__rooms__": "__count__ empty rooms will be removed automatically:
__rooms__.", "__count__message_pruned": "__count__ message pruned", "__count__message_pruned_plural": "__count__ messages pruned", - "__usersCount__members_joined": "+ __usersCount__ members joined", + "__usersCount__member_joined": "+ __usersCount__ member joined", + "__usersCount__member_joined_plural": "+ __usersCount__ members joined", "__usersCount__people_will_be_invited": "__usersCount__ people will be invited", "__username__is_no_longer__role__defined_by__user_by_": "__username__ is no longer __role__ by __user_by__", "__username__was_set__role__by__user_by_": "__username__ was set __role__ by __user_by__", @@ -774,6 +775,7 @@ "By_author": "By __author__", "cache_cleared": "Cache cleared", "Call": "Call", + "Call_back": "Call back", "Calling": "Calling", "Call_Center": "Voice Channel", "Call_Center_Description": "Configure Rocket.Chat's voice channels", @@ -791,7 +793,9 @@ "Call_number_enterprise_only": "Call number (Enterprise Edition only)", "call-management": "Call Management", "call-management_description": "Permission to start a meeting", + "Call_ongoing": "Call ongoing", "Call_unavailable_for_federation": "Call is unavailable for Federated rooms", + "Call_was_not_answered": "Call was not answered", "Caller": "Caller", "Caller_Id": "Caller ID", "Cam_on": "Cam On", @@ -5120,6 +5124,8 @@ "Video_Conference": "Conference Call", "Video_Call_unavailable_for_federation": "Video Call is unavailable for Federated rooms", "Video_Conferences": "Conference Calls", + "Video_Conference_Info": "Meeting Information", + "Video_Conference_Url": "Meeting URL", "video-conf-provider-not-configured": "**Conference call not enabled**: A workspace admin needs to enable the conference calls feature first.", "Video_message": "Video message", "Videocall_declined": "Video Call Declined.", @@ -5287,6 +5293,7 @@ "VoIP_Toggle": "Enable/Disable VoIP", "Chat_opened_by_visitor": "Chat opened by the visitor", "Wait_activation_warning": "Before you can login, your account must be manually activated by an administrator.", + "Waiting_for_answer": "Waiting for answer", "Waiting_queue": "Waiting queue", "Waiting_queue_message": "Waiting queue message", "Waiting_queue_message_description": "Message that will be displayed to the visitors when they get in the queue", diff --git a/apps/meteor/server/models/raw/Messages.ts b/apps/meteor/server/models/raw/Messages.ts index 74a29de0e706d..36d27fbb7d68d 100644 --- a/apps/meteor/server/models/raw/Messages.ts +++ b/apps/meteor/server/models/raw/Messages.ts @@ -247,20 +247,6 @@ export class MessagesRaw extends BaseRaw implements IMessagesModel { await this.updateOne({ _id }, { $addToSet: { blocks: { $each: blocks } } }); } - async removeVideoConfJoinButton(_id: IMessage['_id']): Promise { - await this.updateOne( - { _id }, - { - $pull: { - blocks: { - appId: 'videoconf-core', - type: 'actions', - } as Required['blocks'][number], - }, - }, - ); - } - async countRoomsWithStarredMessages(options: AggregateOptions): Promise { const queryResult = await this.col .aggregate<{ _id: null; total: number }>( diff --git a/apps/meteor/server/models/raw/VideoConference.ts b/apps/meteor/server/models/raw/VideoConference.ts index 96d6cc7f3111e..4185ed2da5074 100644 --- a/apps/meteor/server/models/raw/VideoConference.ts +++ b/apps/meteor/server/models/raw/VideoConference.ts @@ -189,7 +189,10 @@ export class VideoConferenceRaw extends BaseRaw implements IVid }); } - public async addUserById(callId: string, user: Pick & { ts?: Date }): Promise { + public async addUserById( + callId: string, + user: Required> & { ts?: Date }, + ): Promise { await this.updateOneById(callId, { $addToSet: { users: { diff --git a/apps/meteor/server/modules/core-apps/videoconf.module.ts b/apps/meteor/server/modules/core-apps/videoconf.module.ts index f9133625e4957..cf8954e079524 100644 --- a/apps/meteor/server/modules/core-apps/videoconf.module.ts +++ b/apps/meteor/server/modules/core-apps/videoconf.module.ts @@ -1,3 +1,5 @@ +import { TAPi18n } from 'meteor/rocketchat:tap-i18n'; + import type { IUiKitCoreApp } from '../../sdk/types/IUiKitCoreApp'; import { VideoConf } from '../../sdk'; @@ -6,6 +8,7 @@ export class VideoConfModule implements IUiKitCoreApp { async blockAction(payload: any): Promise { const { + triggerId, actionId, payload: { blockId: callId }, user: { _id: userId }, @@ -14,5 +17,35 @@ export class VideoConfModule implements IUiKitCoreApp { if (actionId === 'join') { VideoConf.join(userId, callId, {}); } + + if (actionId === 'info') { + const blocks = await VideoConf.getInfo(callId, userId); + + return { + type: 'modal.open', + triggerId, + appId: this.appId, + view: { + appId: this.appId, + type: 'modal', + id: `${callId}-info`, + title: { + type: 'plain_text', + text: TAPi18n.__('Video_Conference_Info'), + emoji: false, + }, + close: { + type: 'button', + text: { + type: 'plain_text', + text: TAPi18n.__('Close'), + emoji: false, + }, + actionId: 'cancel', + }, + blocks, + }, + }; + } } } diff --git a/apps/meteor/server/modules/listeners/listeners.module.ts b/apps/meteor/server/modules/listeners/listeners.module.ts index 75ca7aa7a587d..0f546ac8d5062 100644 --- a/apps/meteor/server/modules/listeners/listeners.module.ts +++ b/apps/meteor/server/modules/listeners/listeners.module.ts @@ -130,6 +130,12 @@ export class ListenersModule { notifications.streamRoomMessage.emitWithoutBroadcast(message.rid, message); }); + service.onEvent('message.update', ({ message }) => { + if (message.rid) { + notifications.streamRoomMessage.emitWithoutBroadcast(message.rid, message); + } + }); + service.onEvent('watch.subscriptions', ({ clientAction, subscription }) => { if (!subscription.u?._id) { return; diff --git a/apps/meteor/server/sdk/lib/Events.ts b/apps/meteor/server/sdk/lib/Events.ts index 6d1b1b3fc3364..236dcea72befd 100644 --- a/apps/meteor/server/sdk/lib/Events.ts +++ b/apps/meteor/server/sdk/lib/Events.ts @@ -22,6 +22,7 @@ import type { IWebdavAccount, ICustomSound, VoipEventDataSignature, + AtLeast, UserStatus, } from '@rocket.chat/core-typings'; @@ -138,4 +139,5 @@ export type EventSignatures = { 'call.callerhangup'(userId: string, data: { roomId: string }): void; 'watch.pbxevents'(data: { clientAction: ClientAction; data: Partial; id: string }): void; 'connector.statuschanged'(enabled: boolean): void; + 'message.update'(data: { message: AtLeast }): void; }; diff --git a/apps/meteor/server/sdk/types/IVideoConfService.ts b/apps/meteor/server/sdk/types/IVideoConfService.ts index 5c6f9037f918c..f8186212e16fd 100644 --- a/apps/meteor/server/sdk/types/IVideoConfService.ts +++ b/apps/meteor/server/sdk/types/IVideoConfService.ts @@ -8,6 +8,7 @@ import type { VideoConferenceInstructions, } from '@rocket.chat/core-typings'; import type { PaginatedResult } from '@rocket.chat/rest-typings'; +import type { IBlock } from '@rocket.chat/apps-engine/definition/uikit'; export type VideoConferenceJoinOptions = { mic?: boolean; @@ -18,6 +19,7 @@ export interface IVideoConfService { create(data: VideoConferenceCreateData, useAppUser?: boolean): Promise; start(caller: IUser['_id'], rid: string, options: { title?: string; allowRinging?: boolean }): Promise; join(uid: IUser['_id'] | undefined, callId: VideoConference['_id'], options: VideoConferenceJoinOptions): Promise; + getInfo(callId: VideoConference['_id'], uid: IUser['_id'] | undefined): Promise; cancel(uid: IUser['_id'], callId: VideoConference['_id']): Promise; get(callId: VideoConference['_id']): Promise | null>; getUnfiltered(callId: VideoConference['_id']): Promise; diff --git a/apps/meteor/server/services/video-conference/service.ts b/apps/meteor/server/services/video-conference/service.ts index 0808e685ba516..f367940f24e2c 100644 --- a/apps/meteor/server/services/video-conference/service.ts +++ b/apps/meteor/server/services/video-conference/service.ts @@ -10,6 +10,7 @@ import type { LivechatInstructions, AtLeast, IGroupVideoConference, + IVideoConferenceUser, IMessage, IStats, VideoConference, @@ -23,8 +24,9 @@ import { isGroupVideoConference, isLivechatVideoConference, } from '@rocket.chat/core-typings'; -import type { MessageSurfaceLayout, ContextBlock } from '@rocket.chat/ui-kit'; +import type { MessageSurfaceLayout } from '@rocket.chat/ui-kit'; import type { AppVideoConfProviderManager } from '@rocket.chat/apps-engine/server/managers'; +import type { IBlock } from '@rocket.chat/apps-engine/definition/uikit'; import { TAPi18n } from 'meteor/rocketchat:tap-i18n'; import type { PaginatedResult } from '@rocket.chat/rest-typings'; import { Users, VideoConference as VideoConferenceModel, Rooms, Messages, Subscriptions } from '@rocket.chat/models'; @@ -34,7 +36,6 @@ import { ServiceClassInternal } from '../../sdk/types/ServiceClass'; import { Apps } from '../../../app/apps/server'; import { sendMessage } from '../../../app/lib/server/functions/sendMessage'; import { settings } from '../../../app/settings/server'; -import { getURL } from '../../../app/utils/server'; import { videoConfProviders } from '../../lib/videoConfProviders'; import { videoConfTypes } from '../../lib/videoConfTypes'; import { updateCounter } from '../../../app/statistics/server/functions/updateStatsCounter'; @@ -131,6 +132,50 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf return this.joinCall(call, user || undefined, options); } + public async getInfo(callId: VideoConference['_id'], uid: IUser['_id'] | undefined): Promise { + const call = await VideoConferenceModel.findOneById(callId); + if (!call) { + throw new Error('invalid-call'); + } + + if (!videoConfProviders.isProviderAvailable(call.providerName)) { + throw new Error('video-conf-provider-unavailable'); + } + + let user: Pick, '_id' | 'username' | 'name' | 'avatarETag'> | null = null; + + if (uid) { + user = await Users.findOneById, '_id' | 'username' | 'name' | 'avatarETag'>>(uid, { + projection: { name: 1, username: 1, avatarETag: 1 }, + }); + if (!user) { + throw new Error('failed-to-load-own-data'); + } + } + + const blocks = await (await this.getProviderManager()).getVideoConferenceInfo(call.providerName, call, user || undefined).catch((e) => { + throw new Error(e); + }); + + if (blocks?.length) { + return blocks; + } + + return [ + { + blockId: 'id', + type: 'context', + elements: [ + { + type: 'plain_text', + text: `${TAPi18n.__('Video_Conference_Url')}: ${call.url}`, + emoji: false, + }, + ], + } as IBlock, + ]; + } + public async cancel(uid: IUser['_id'], callId: VideoConference['_id']): Promise { const call = await VideoConferenceModel.findOneById(callId); if (!call || !isDirectVideoConference(call)) { @@ -146,23 +191,19 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf throw new Error('failed-to-load-own-data'); } - if (call.messages.started) { - const name = - (settings.get('UI_Use_Real_Name') ? call.createdBy.name : call.createdBy.username) || call.createdBy.username || ''; - const text = TAPi18n.__('video_direct_missed', { username: name }); - await Messages.setBlocksById(call.messages.started, [this.buildMessageBlock(text)]); - } - await VideoConferenceModel.setDataById(callId, { ringing: false, status: VideoConferenceStatus.DECLINED, endedAt: new Date(), endedBy: { _id: user._id, - name: user.name, - username: user.username, + name: user.name as string, + username: user.username as string, }, }); + + await this.runVideoConferenceChangedEvent(callId); + this.notifyVideoConfUpdate(call.rid, call._id); } public async get(callId: VideoConference['_id']): Promise | null> { @@ -237,8 +278,8 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf throw new Error('Invalid User'); } - const user = await Users.findOneById>>(userId, { - projection: { username: 1, name: 1 }, + const user = await Users.findOneById>>(userId, { + projection: { username: 1, name: 1, avatarETag: 1 }, }); if (!user) { throw new Error('Invalid User'); @@ -248,6 +289,7 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf _id: user._id, username: user.username, name: user.name, + avatarETag: user.avatarETag, ts: ts || new Date(), }); } @@ -372,6 +414,10 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf return true; } + private notifyVideoConfUpdate(rid: IRoom['_id'], callId: VideoConference['_id']): void { + Notifications.notifyRoom(rid, callId); + } + private async endCall(callId: VideoConference['_id']): Promise { const call = await this.getUnfiltered(callId); if (!call) { @@ -379,13 +425,11 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf } await VideoConferenceModel.setDataById(call._id, { endedAt: new Date(), status: VideoConferenceStatus.ENDED }); - if (call.messages?.started) { - await this.removeJoinButton(call.messages.started); - } + await this.runVideoConferenceChangedEvent(call._id); + this.notifyVideoConfUpdate(call.rid, call._id); - switch (call.type) { - case 'direct': - return this.endDirectCall(call); + if (call.type === 'direct') { + return this.endDirectCall(call); } } @@ -396,16 +440,6 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf } await VideoConferenceModel.setDataById(call._id, { endedAt: new Date(), status: VideoConferenceStatus.EXPIRED }); - if (call.messages?.started) { - return this.removeJoinButton(call.messages.started); - } - } - - private async removeJoinButton(messageId: IMessage['_id']): Promise { - await Messages.removeVideoConfJoinButton(messageId); - - const text = TAPi18n.__('Conference_call_has_ended'); - await Messages.addBlocksById(messageId, [this.buildMessageBlock(text)]); } private async endDirectCall(call: IDirectVideoConference): Promise { @@ -443,66 +477,21 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf return videoConfTypes.getTypeForRoom(room, allowRinging); } - private async createMessage( - rid: IRoom['_id'], - providerName: string, - extraData: Partial = {}, - createdBy?: IUser, - ): Promise { + private async createMessage(call: VideoConference, createdBy?: IUser, customBlocks?: IMessage['blocks']): Promise { const record = { msg: '', groupable: false, - ...extraData, + blocks: customBlocks || [this.buildVideoConfBlock(call._id)], }; - const room = await Rooms.findOneById(rid); - const appId = videoConfProviders.getProviderAppId(providerName); + const room = await Rooms.findOneById(call.rid); + const appId = videoConfProviders.getProviderAppId(call.providerName); const user = createdBy || (appId && (await Users.findOneByAppId(appId))) || (await Users.findOneById('rocket.cat')); const message = sendMessage(user, record, room, false); return message._id; } - private async createDirectCallMessage(call: IDirectVideoConference, user: IUser): Promise { - const username = (settings.get('UI_Use_Real_Name') ? user.name : user.username) || user.username || ''; - const text = TAPi18n.__('video_direct_calling', { - username, - }); - - return this.createMessage( - call.rid, - call.providerName, - { - blocks: [this.buildMessageBlock(text), this.buildJoinButtonBlock(call._id)], - }, - user, - ); - } - - private async createGroupCallMessage(call: IGroupVideoConference, user: IUser, useAppUser = true): Promise { - const username = (settings.get('UI_Use_Real_Name') ? user.name : user.username) || user.username || ''; - const text = TAPi18n.__(useAppUser ? 'video_conference_started_by' : 'video_conference_started', { - conference: call.title || '', - username, - }); - - return this.createMessage( - call.rid, - call.providerName, - { - blocks: [ - this.buildMessageBlock(text), - this.buildJoinButtonBlock(call._id, call.title), - { - type: 'context', - elements: [], - }, - ], - } as Partial, - useAppUser ? undefined : user, - ); - } - private async validateProvider(providerName: string): Promise { const manager = await this.getProviderManager(); const configured = await manager.isFullyConfigured(providerName).catch(() => false); @@ -545,35 +534,37 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf username, }); - return this.createMessage( - call.rid, - call.providerName, + return this.createMessage(call, user, [ + this.buildMessageBlock(text), { - blocks: [ - this.buildMessageBlock(text), + type: 'actions', + appId: 'videoconf-core', + blockId: call._id, + elements: [ { - type: 'actions', appId: 'videoconf-core', blockId: call._id, - elements: [ - { - appId: 'videoconf-core', - blockId: call._id, - actionId: 'joinLivechat', - type: 'button', - text: { - type: 'plain_text', - text: TAPi18n.__('Join_call'), - emoji: true, - }, - url, - }, - ], + actionId: 'joinLivechat', + type: 'button', + text: { + type: 'plain_text', + text: TAPi18n.__('Join_call'), + emoji: true, + }, + url, }, ], }, - user, - ); + ]); + } + + private buildVideoConfBlock(callId: string): MessageSurfaceLayout[number] { + return { + type: 'video_conf', + blockId: callId, + callId, + appId: 'videoconf-core', + }; } private buildMessageBlock(text: string): MessageSurfaceLayout[number] { @@ -587,27 +578,6 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf }; } - private buildJoinButtonBlock(callId: string, title = ''): MessageSurfaceLayout[number] { - return { - type: 'actions', - appId: 'videoconf-core', - elements: [ - { - appId: 'videoconf-core', - blockId: callId, - actionId: 'join', - value: title, - type: 'button', - text: { - type: 'plain_text', - text: TAPi18n.__('Join_call'), - emoji: true, - }, - }, - ], - }; - } - private async startDirect( providerName: string, user: IUser, @@ -625,8 +595,8 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf rid, createdBy: { _id: user._id, - name: user.name, - username: user.username, + name: user.name as string, + username: user.username as string, }, providerName, }); @@ -635,10 +605,13 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf throw new Error('failed-to-create-direct-call'); } + await this.runNewVideoConferenceEvent(callId); + const url = await this.generateNewUrl(call); VideoConferenceModel.setUrlById(callId, url); - const messageId = await this.createDirectCallMessage(call, user); + const messageId = await this.createMessage(call, user); + call.messages.started = messageId; VideoConferenceModel.setMessageById(callId, 'started', messageId); // After 40 seconds if the status is still "calling", we cancel the call automatically. @@ -685,8 +658,8 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf title, createdBy: { _id: user._id, - name: user.name, - username: user.username, + name: user.name as string, + username: user.username as string, }, providerName, }); @@ -695,12 +668,15 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf throw new Error('failed-to-create-group-call'); } + await this.runNewVideoConferenceEvent(callId); + const url = await this.generateNewUrl(call); VideoConferenceModel.setUrlById(callId, url); call.url = url; - const messageId = await this.createGroupCallMessage(call, user, useAppUser); + const messageId = await this.createMessage(call, useAppUser ? undefined : user); + call.messages.started = messageId; VideoConferenceModel.setMessageById(callId, 'started', messageId); if (call.ringing) { @@ -719,8 +695,8 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf rid, createdBy: { _id: user._id, - name: user.name, - username: user.username, + name: user.name as string, + username: user.username as string, }, providerName, }); @@ -730,8 +706,11 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf throw new Error('failed-to-create-livechat-call'); } + await this.runNewVideoConferenceEvent(callId); + const joinUrl = await this.getUrl(call); const messageId = await this.createLivechatMessage(call, user, joinUrl); + call.messages.started = messageId; await VideoConferenceModel.setMessageById(callId, 'started', messageId); return { @@ -747,6 +726,8 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf ): Promise { await callbacks.runAsync('onJoinVideoConference', call._id, user?._id); + await this.runOnUserJoinEvent(call._id, user as IVideoConferenceUser); + return this.getUrl(call, user, options); } @@ -867,74 +848,73 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf }); } - private async addUserToCall( - call: Optional, - { _id, username, name, avatarETag, ts }: AtLeast & { ts?: Date }, - ): Promise { - if (call.users.find((user) => user._id === _id)) { - return; - } + private async runNewVideoConferenceEvent(callId: VideoConference['_id']): Promise { + const call = await VideoConferenceModel.findOneById(callId); - await VideoConferenceModel.addUserById(call._id, { _id, username, name, avatarETag, ts }); + if (!call) { + throw new Error('video-conf-data-not-found'); + } - switch (call.type) { - case 'videoconference': - return this.updateGroupCallMessage(call as IGroupVideoConference, { _id, username, name }); - case 'direct': - return this.updateDirectCall(call as IDirectVideoConference, _id); + if (!videoConfProviders.isProviderAvailable(call.providerName)) { + throw new Error('video-conf-provider-unavailable'); } + + (await this.getProviderManager()).onNewVideoConference(call.providerName, call).catch((e) => { + throw new Error(e); + }); } - private async addAnonymousUser(call: Optional): Promise { - await VideoConferenceModel.increaseAnonymousCount(call._id); + private async runVideoConferenceChangedEvent(callId: VideoConference['_id']): Promise { + const call = await VideoConferenceModel.findOneById(callId); - if (!call.messages.started) { - return; + if (!call) { + throw new Error('video-conf-data-not-found'); } - const imageUrl = getURL(`/avatar/@a`, { cdn: false, full: true }); - return this.addAvatarToCallMessage(call.messages.started, imageUrl, TAPi18n.__('Anonymous')); - } - - private async addAvatarToCallMessage(messageId: IMessage['_id'], imageUrl: string, altText: string): Promise { - const message = await Messages.findOneById>(messageId, { projection: { blocks: 1 } }); - if (!message) { - return; + if (!videoConfProviders.isProviderAvailable(call.providerName)) { + throw new Error('video-conf-provider-unavailable'); } - const blocks = message.blocks || []; + (await this.getProviderManager()).onVideoConferenceChanged(call.providerName, call).catch((e) => { + throw new Error(e); + }); + } - const avatarsBlock = (blocks.find((block) => block.type === 'context') || { type: 'context', elements: [] }) as ContextBlock; - if (!blocks.includes(avatarsBlock)) { - blocks.push(avatarsBlock); - } + private async runOnUserJoinEvent(callId: VideoConference['_id'], user?: IVideoConferenceUser): Promise { + const call = await VideoConferenceModel.findOneById(callId); - if (avatarsBlock.elements.find((el) => el.type === 'image' && el.imageUrl === imageUrl)) { - return; + if (!call) { + throw new Error('video-conf-data-not-found'); } - avatarsBlock.elements = [ - ...avatarsBlock.elements, - { - type: 'image', - imageUrl, - altText, - }, - ]; + if (!videoConfProviders.isProviderAvailable(call.providerName)) { + throw new Error('video-conf-provider-unavailable'); + } - await Messages.setBlocksById(message._id, blocks); + (await this.getProviderManager()).onUserJoin(call.providerName, call, user).catch((e) => { + throw new Error(e); + }); } - private async updateGroupCallMessage( - call: Optional, - user: Pick, + private async addUserToCall( + call: Optional, + { _id, username, name, avatarETag, ts }: AtLeast, '_id' | 'username' | 'name' | 'avatarETag'> & { ts?: Date }, ): Promise { - if (!call.messages.started || !user.username) { + if (call.users.find((user) => user._id === _id)) { return; } - const imageUrl = getURL(`/avatar/${user.username}`, { cdn: false, full: true }); - return this.addAvatarToCallMessage(call.messages.started, imageUrl, user.name || user.username); + await VideoConferenceModel.addUserById(call._id, { _id, username, name, avatarETag, ts }); + + if (call.type === 'direct') { + return this.updateDirectCall(call as IDirectVideoConference, _id); + } + + this.notifyVideoConfUpdate(call.rid, call._id); + } + + private async addAnonymousUser(call: Optional): Promise { + await VideoConferenceModel.increaseAnonymousCount(call._id); } private async updateDirectCall(call: IDirectVideoConference, newUserId: IUser['_id']): Promise { @@ -953,12 +933,8 @@ export class VideoConfService extends ServiceClassInternal implements IVideoConf } await VideoConferenceModel.setStatusById(call._id, VideoConferenceStatus.STARTED); + this.notifyVideoConfUpdate(call.rid, call._id); - if (call.messages.started) { - const username = - (settings.get('UI_Use_Real_Name') ? call.createdBy.name : call.createdBy.username) || call.createdBy.username || ''; - const text = TAPi18n.__('video_direct_started', { username }); - await Messages.setBlocksById(call.messages.started, [this.buildMessageBlock(text), this.buildJoinButtonBlock(call._id)]); - } + await this.runVideoConferenceChangedEvent(call._id); } } diff --git a/ee/apps/ddp-streamer/package.json b/ee/apps/ddp-streamer/package.json index 5aa01fa2826a4..303c79e558f01 100644 --- a/ee/apps/ddp-streamer/package.json +++ b/ee/apps/ddp-streamer/package.json @@ -47,7 +47,7 @@ "@types/sharp": "^0.30.4", "@types/uuid": "^8.3.4", "@types/ws": "^8.5.3", - "eslint": "^8.21.0", + "eslint": "^8.22.0", "pino-pretty": "^7.6.1", "ts-node": "^10.9.1", "typescript": "~4.5.5" diff --git a/packages/agenda/package.json b/packages/agenda/package.json index 5ca16adef570f..e2a0613c80482 100644 --- a/packages/agenda/package.json +++ b/packages/agenda/package.json @@ -14,7 +14,7 @@ "devDependencies": { "@types/debug": "^4", "@types/jest": "^27.4.1", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "ts-jest": "^27.1.4", "typescript": "~4.5.5" diff --git a/packages/api-client/package.json b/packages/api-client/package.json index 98f63afd69abc..f9c9b1466a5d9 100644 --- a/packages/api-client/package.json +++ b/packages/api-client/package.json @@ -5,7 +5,7 @@ "devDependencies": { "@types/jest": "^27.4.1", "@types/strict-uri-encode": "^2.0.0", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "ts-jest": "^27.1.5", "typescript": "~4.5.5" diff --git a/packages/cas-validate/package.json b/packages/cas-validate/package.json index c8f23b455c7ac..22cc27646cd73 100644 --- a/packages/cas-validate/package.json +++ b/packages/cas-validate/package.json @@ -5,7 +5,7 @@ "private": true, "devDependencies": { "@types/jest": "^27.4.1", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "ts-jest": "^27.1.4", "typescript": "~4.5.5" diff --git a/packages/core-typings/package.json b/packages/core-typings/package.json index f50ef575f79da..da84a1ce3c552 100644 --- a/packages/core-typings/package.json +++ b/packages/core-typings/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "@rocket.chat/eslint-config": "workspace:^", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "mongodb": "^4.3.1", "prettier": "^2.7.1", "typescript": "~4.5.5" diff --git a/packages/core-typings/src/IVideoConference.ts b/packages/core-typings/src/IVideoConference.ts index a4c0b57134716..5d36287aa9b4a 100644 --- a/packages/core-typings/src/IVideoConference.ts +++ b/packages/core-typings/src/IVideoConference.ts @@ -31,7 +31,7 @@ export type LivechatInstructions = { export type VideoConferenceType = DirectCallInstructions['type'] | ConferenceInstructions['type'] | LivechatInstructions['type']; -export interface IVideoConferenceUser extends Pick { +export interface IVideoConferenceUser extends Pick, '_id' | 'username' | 'name' | 'avatarETag'> { ts: Date; } @@ -46,10 +46,10 @@ export interface IVideoConference extends IRocketChatRecord { }; url?: string; - createdBy: Pick; + createdBy: Pick, '_id' | 'username' | 'name'>; createdAt: Date; - endedBy?: Pick; + endedBy?: Pick, '_id' | 'username' | 'name'>; endedAt?: Date; providerName: string; diff --git a/packages/eslint-config/package.json b/packages/eslint-config/package.json index cc850fdaa0b51..2e028655e6a1e 100644 --- a/packages/eslint-config/package.json +++ b/packages/eslint-config/package.json @@ -7,7 +7,7 @@ "@types/prettier": "^2.6.3", "@typescript-eslint/eslint-plugin": "^5.30.7", "@typescript-eslint/parser": "^5.30.7", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "eslint-config-prettier": "^8.5.0", "eslint-plugin-anti-trojan-source": "^1.1.0", "eslint-plugin-import": "^2.26.0", diff --git a/packages/favicon/package.json b/packages/favicon/package.json index 7dba2d92dad34..a50c9aca6d8bf 100644 --- a/packages/favicon/package.json +++ b/packages/favicon/package.json @@ -3,7 +3,7 @@ "version": "0.0.1", "private": true, "devDependencies": { - "eslint": "^8.20.0", + "eslint": "^8.22.0", "typescript": "~4.5.5" }, "scripts": { diff --git a/packages/fuselage-ui-kit/package.json b/packages/fuselage-ui-kit/package.json index b4bd0afcc1f02..7f6d5eeb8a17f 100644 --- a/packages/fuselage-ui-kit/package.json +++ b/packages/fuselage-ui-kit/package.json @@ -38,23 +38,33 @@ "bump-next": "bump-next" }, "peerDependencies": { + "@rocket.chat/apps-engine": "*", + "@rocket.chat/eslint-config": "*", "@rocket.chat/fuselage": "*", "@rocket.chat/fuselage-hooks": "*", "@rocket.chat/fuselage-polyfills": "*", "@rocket.chat/icons": "*", + "@rocket.chat/prettier-config": "*", "@rocket.chat/styled": "*", - "react": "^17.0.2", - "react-dom": "^17.0.2" + "@rocket.chat/ui-contexts": "*", + "@rocket.chat/ui-kit": "*", + "@rocket.chat/ui-video-conf": "*", + "@tanstack/react-query": "*", + "react": "*", + "react-dom": "*" }, "devDependencies": { "@rocket.chat/apps-engine": "~1.30.0", "@rocket.chat/eslint-config": "workspace:^", "@rocket.chat/fuselage": "next", - "@rocket.chat/fuselage-hooks": "0.31.21", - "@rocket.chat/fuselage-polyfills": "0.31.21", - "@rocket.chat/icons": "0.31.21", + "@rocket.chat/fuselage-hooks": "next", + "@rocket.chat/fuselage-polyfills": "next", + "@rocket.chat/icons": "next", "@rocket.chat/prettier-config": "next", - "@rocket.chat/styled": "0.31.21", + "@rocket.chat/styled": "next", + "@rocket.chat/ui-contexts": "workspace:^", + "@rocket.chat/ui-kit": "next", + "@rocket.chat/ui-video-conf": "workspace:^", "@storybook/addon-essentials": "~6.5.10", "@storybook/addons": "~6.5.10", "@storybook/builder-webpack5": "~6.5.10", @@ -62,23 +72,24 @@ "@storybook/react": "~6.5.10", "@storybook/source-loader": "~6.5.10", "@storybook/theming": "~6.5.10", - "@types/react": "~17.0.39", - "@types/react-dom": "^17.0.11", + "@tanstack/react-query": "^4.16.1", + "@types/react": "~17.0.48", + "@types/react-dom": "~17.0.17", "babel-loader": "~8.2.3", "cross-env": "^7.0.3", - "eslint": "~8.8.0", + "eslint": "~8.22.0", "lint-staged": "~12.3.3", "normalize.css": "^8.0.1", "npm-run-all": "^4.1.5", "prettier": "~2.5.1", - "react": "^17.0.2", "react-dom": "^17.0.2", "rimraf": "^3.0.2", + "tslib": "^2.3.1", "typescript": "~4.3.5", "webpack": "~5.68.0" }, "dependencies": { - "@rocket.chat/ui-kit": "0.31.21", + "@rocket.chat/ui-kit": "0.31.20", "tslib": "^2.3.1" } } diff --git a/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/VideoConferenceBlock.tsx b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/VideoConferenceBlock.tsx new file mode 100644 index 0000000000000..57fb37fe8a3b8 --- /dev/null +++ b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/VideoConferenceBlock.tsx @@ -0,0 +1,191 @@ +import type * as UiKit from '@rocket.chat/ui-kit'; +import { useTranslation } from '@rocket.chat/ui-contexts'; +import { + VideoConfMessageSkeleton, + VideoConfMessage, + VideoConfMessageRow, + VideoConfMessageIcon, + VideoConfMessageText, + VideoConfMessageFooter, + VideoConfMessageUserStack, + VideoConfMessageFooterText, + VideoConfMessageButton, + VideoConfMessageContent, + VideoConfMessageActions, + VideoConfMessageAction, +} from '@rocket.chat/ui-video-conf'; +import type { MouseEventHandler, ReactElement } from 'react'; +import React, { useContext, memo } from 'react'; + +import { useSurfaceType } from '../../contexts/SurfaceContext'; +import type { BlockProps } from '../../utils/BlockProps'; +import { useVideoConfDataStream } from './hooks/useVideoConfDataStream'; +import { kitContext } from '../..'; + +type VideoConferenceBlockProps = BlockProps; + +const MAX_USERS = 6; + +const VideoConferenceBlock = ({ + block, +}: VideoConferenceBlockProps): ReactElement => { + const t = useTranslation(); + const { callId, appId = 'videoconf-core' } = block; + const surfaceType = useSurfaceType(); + + const { action, viewId, rid } = useContext(kitContext); + + if (surfaceType !== 'message') { + return <>; + } + + if (!callId || !rid) { + return <>; + } + + const result = useVideoConfDataStream({ rid, callId }); + + const joinHandler: MouseEventHandler = (e): void => { + action( + { + blockId: block.blockId || '', + appId, + actionId: 'join', + value: block.blockId || '', + viewId, + }, + e + ); + }; + + const callAgainHandler: MouseEventHandler = (e): void => { + action( + { + blockId: rid || '', + appId, + actionId: 'callBack', + value: rid || '', + viewId, + }, + e + ); + }; + + const openCallInfo: MouseEventHandler = (e) => { + action( + { + blockId: callId, + appId, + actionId: 'info', + value: rid, + viewId, + }, + e + ); + }; + + if (result.isSuccess) { + const { data } = result; + + if ('endedAt' in data) { + return ( + + + + + {t('Call_ended')} + + + + + + + {data.type === 'direct' && ( + <> + + {t('Call_back')} + + + {t('Call_was_not_answered')} + + + )} + {data.type !== 'direct' && + (data.users.length ? ( + <> + + + {data.users.length > MAX_USERS + ? t('__usersCount__member_joined', { + usersCount: data.users.length - MAX_USERS, + }) + : t('joined')} + + + ) : ( + + {t('Call_was_not_answered')} + + ))} + + + ); + } + + if (data.type === 'direct' && data.status === 0) { + return ( + + + + + {t('Calling')} + + + + + + + + {t('Waiting_for_answer')} + + + + ); + } + + return ( + + + + + {t('Call_ongoing')} + + + + + + + + {t('Join')} + + {data.users.length && ( + <> + + + {data.users.length > MAX_USERS + ? t('__usersCount__member_joined', { + usersCount: data.users.length - MAX_USERS, + }) + : t('joined')} + + + )} + + + ); + } + + return ; +}; + +export default memo(VideoConferenceBlock); diff --git a/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/hooks/useVideoConfData.ts b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/hooks/useVideoConfData.ts new file mode 100644 index 0000000000000..23b67327bba20 --- /dev/null +++ b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/hooks/useVideoConfData.ts @@ -0,0 +1,22 @@ +import { useQuery } from '@tanstack/react-query'; +import { useEndpoint } from '@rocket.chat/ui-contexts'; + +export const useVideoConfData = ({ callId }: { callId: string }) => { + const getVideoConfInfo = useEndpoint('GET', '/v1/video-conference.info'); + + return useQuery( + ['video-conference', callId], + () => getVideoConfInfo({ callId }), + { + staleTime: Infinity, + refetchOnWindowFocus: false, + refetchOnMount: (query) => { + if (query.state.data?.endedAt) { + return false; + } + + return 'always'; + }, + } + ); +}; diff --git a/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/hooks/useVideoConfDataStream.ts b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/hooks/useVideoConfDataStream.ts new file mode 100644 index 0000000000000..dad9d5795eb38 --- /dev/null +++ b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/hooks/useVideoConfDataStream.ts @@ -0,0 +1,75 @@ +import { useStream } from '@rocket.chat/ui-contexts'; +import { Emitter } from '@rocket.chat/emitter'; +import { useCallback, useEffect } from 'react'; +import { useQueryClient } from '@tanstack/react-query'; + +import { useVideoConfData } from './useVideoConfData'; + +const ee = new Emitter>(); + +const events = new Map void>(); + +const useStreamBySubPath = ( + streamer: ReturnType, + subpath: string, + callback: () => void +) => { + const maybeSubscribe = useCallback(() => { + // If we're already subscribed, don't do it again + if (events.has(subpath)) { + return; + } + + events.set( + subpath, + streamer(subpath, () => { + ee.emit(subpath); + }) + ); + }, [streamer, subpath]); + + const maybeUnsubscribe = useCallback(() => { + // If someone is still listening, don't unsubscribe + if (ee.has(subpath)) { + return; + } + + const unsubscribe = events.get(subpath); + if (unsubscribe) { + unsubscribe(); + events.delete(subpath); + } + }, [subpath]); + + useEffect(() => { + maybeSubscribe(); + ee.on(subpath, callback); + + return () => { + ee.off(subpath, callback); + maybeUnsubscribe(); + }; + }, [callback, subpath]); +}; + +export const useVideoConfDataStream = ({ + rid, + callId, +}: { + rid: string; + callId: string; +}) => { + const queryClient = useQueryClient(); + const subpath = `${rid}/${callId}`; + + const subscribeNotifyRoom = useStream('notify-room'); + + useStreamBySubPath( + subscribeNotifyRoom, + subpath, + useCallback(() => { + queryClient.invalidateQueries(['video-conference', callId]); + }, [subpath]) + ); + return useVideoConfData({ callId }); +}; diff --git a/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/index.tsx b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/index.tsx new file mode 100644 index 0000000000000..bbd942c7d3feb --- /dev/null +++ b/packages/fuselage-ui-kit/src/blocks/VideoConferenceBlock/index.tsx @@ -0,0 +1,3 @@ +import VideoConferenceBlock from './VideoConferenceBlock'; + +export default VideoConferenceBlock; diff --git a/packages/fuselage-ui-kit/src/contexts/kitContext.ts b/packages/fuselage-ui-kit/src/contexts/kitContext.ts index b0cb4141b1618..6eebb8cea7a68 100644 --- a/packages/fuselage-ui-kit/src/contexts/kitContext.ts +++ b/packages/fuselage-ui-kit/src/contexts/kitContext.ts @@ -23,6 +23,7 @@ type UiKitContext = { errors?: Record; values: Record; viewId?: string; + rid?: string; }; export const defaultContext = { diff --git a/packages/fuselage-ui-kit/src/surfaces/FuselageSurfaceRenderer.tsx b/packages/fuselage-ui-kit/src/surfaces/FuselageSurfaceRenderer.tsx index f548f63ac6755..fe2e61ee590fd 100644 --- a/packages/fuselage-ui-kit/src/surfaces/FuselageSurfaceRenderer.tsx +++ b/packages/fuselage-ui-kit/src/surfaces/FuselageSurfaceRenderer.tsx @@ -18,17 +18,23 @@ import OverflowElement from '../elements/OverflowElement'; import PlainTextInputElement from '../elements/PlainTextInputElement'; import StaticSelectElement from '../elements/StaticSelectElement'; +type FuselageSurfaceRendererProps = ConstructorParameters< + typeof UiKit.SurfaceRenderer +>[0]; + export class FuselageSurfaceRenderer extends UiKit.SurfaceRenderer { - public constructor() { - super([ - 'actions', - 'context', - 'divider', - 'image', - 'input', - 'section', - 'preview', - ]); + public constructor(allowedBlocks?: FuselageSurfaceRendererProps) { + super( + allowedBlocks || [ + 'actions', + 'context', + 'divider', + 'image', + 'input', + 'section', + 'preview', + ] + ); } public plain_text( diff --git a/packages/fuselage-ui-kit/src/surfaces/MessageSurfaceRenderer.tsx b/packages/fuselage-ui-kit/src/surfaces/MessageSurfaceRenderer.tsx new file mode 100644 index 0000000000000..6d83d774a9ed3 --- /dev/null +++ b/packages/fuselage-ui-kit/src/surfaces/MessageSurfaceRenderer.tsx @@ -0,0 +1,41 @@ +import * as UiKit from '@rocket.chat/ui-kit'; +import type { ReactElement } from 'react'; +import React from 'react'; + +import VideoConferenceBlock from '../blocks/VideoConferenceBlock/VideoConferenceBlock'; +import { FuselageSurfaceRenderer } from './FuselageSurfaceRenderer'; + +export class FuselageMessageSurfaceRenderer extends FuselageSurfaceRenderer { + public constructor() { + super([ + 'actions', + 'context', + 'divider', + 'image', + 'input', + 'section', + 'preview', + 'video_conf', + ]); + } + + video_conf( + block: UiKit.VideoConferenceBlock, + context: UiKit.BlockContext, + index: number + ): ReactElement | null { + if (context === UiKit.BlockContext.BLOCK) { + return ( + + ); + } + + return null; + } +} diff --git a/packages/fuselage-ui-kit/src/surfaces/index.ts b/packages/fuselage-ui-kit/src/surfaces/index.ts index dd29183435907..49eff1a923a5c 100644 --- a/packages/fuselage-ui-kit/src/surfaces/index.ts +++ b/packages/fuselage-ui-kit/src/surfaces/index.ts @@ -3,10 +3,11 @@ import { FuselageSurfaceRenderer } from './FuselageSurfaceRenderer'; import MessageSurface from './MessageSurface'; import ModalSurface from './ModalSurface'; import { createSurfaceRenderer } from './createSurfaceRenderer'; +import { FuselageMessageSurfaceRenderer } from './MessageSurfaceRenderer'; // export const attachmentParser = new FuselageSurfaceRenderer(); export const bannerParser = new FuselageSurfaceRenderer(); -export const messageParser = new FuselageSurfaceRenderer(); +export const messageParser = new FuselageMessageSurfaceRenderer(); export const modalParser = new FuselageSurfaceRenderer(); // export const UiKitAttachment = createSurfaceRenderer(AttachmentSurface, attachmentParser); diff --git a/packages/gazzodown/package.json b/packages/gazzodown/package.json index c64b45de97b29..9f094c8c7d605 100644 --- a/packages/gazzodown/package.json +++ b/packages/gazzodown/package.json @@ -3,7 +3,7 @@ "version": "0.0.1", "private": true, "devDependencies": { - "@babel/core": "^7.18.9", + "@babel/core": "~7.18.13", "@mdx-js/react": "^1.6.22", "@rocket.chat/core-typings": "workspace:^", "@rocket.chat/css-in-js": "0.31.21", @@ -27,13 +27,13 @@ "@types/babel__core": "^7", "@types/jest": "^27.4.1", "@types/katex": "~0", - "@types/react": "^17.0.47", - "@types/react-dom": "^18", + "@types/react": "~17.0.48", + "@types/react-dom": "~17.0.17", "@types/testing-library__jest-dom": "^5", "@typescript-eslint/eslint-plugin": "^5.30.7", "@typescript-eslint/parser": "^5.30.7", "babel-loader": "^8.2.5", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "eslint-plugin-anti-trojan-source": "^1.1.0", "eslint-plugin-react": "^7.30.1", "eslint-plugin-react-hooks": "^4.6.0", @@ -61,16 +61,16 @@ "/dist" ], "peerDependencies": { - "@rocket.chat/core-typings": "workspace:^", + "@rocket.chat/core-typings": "*", "@rocket.chat/css-in-js": "*", "@rocket.chat/fuselage": "*", "@rocket.chat/fuselage-tokens": "*", "@rocket.chat/message-parser": "*", "@rocket.chat/styled": "*", - "@rocket.chat/ui-client": "workspace:^", - "@rocket.chat/ui-contexts": "workspace:^", + "@rocket.chat/ui-client": "*", + "@rocket.chat/ui-contexts": "*", "katex": "*", - "react": "~17.0.2" + "react": "*" }, "dependencies": { "highlight.js": "^11.5.1", diff --git a/packages/livechat/package.json b/packages/livechat/package.json index 8d63e6c51fd7a..4c9397b0b189b 100644 --- a/packages/livechat/package.json +++ b/packages/livechat/package.json @@ -25,7 +25,7 @@ }, "devDependencies": { "@babel/eslint-parser": "^7.18.9", - "@babel/preset-env": "^7.18.9", + "@babel/preset-env": "^7.18.10", "@rocket.chat/eslint-config": "^0.4.0", "@rocket.chat/fuselage-tokens": "0.31.21", "@rocket.chat/logo": "0.31.21", @@ -37,7 +37,6 @@ "@storybook/addon-viewport": "~6.5.10", "@storybook/react": "~6.5.10", "@storybook/theming": "~6.5.10", - "@types/react-dom": "^17.0.17", "autoprefixer": "^9.8.8", "babel-loader": "^8.1.0", "babel-plugin-jsx-pragmatic": "^1.0.2", @@ -45,7 +44,7 @@ "css-loader": "^4.3.0", "cssnano": "^4.1.11", "desvg-loader": "^0.1.0", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "eslint-plugin-import": "^2.26.0", "eslint-plugin-react": "^7.30.1", "eslint-plugin-react-hooks": "^4.6.0", diff --git a/packages/livechat/src/components/Messages/MessageList/index.js b/packages/livechat/src/components/Messages/MessageList/index.js index 7ac2dbf60ab85..f7ab458c017fe 100644 --- a/packages/livechat/src/components/Messages/MessageList/index.js +++ b/packages/livechat/src/components/Messages/MessageList/index.js @@ -101,7 +101,9 @@ export class MessageList extends MemoizedComponent { isVideoConfMessage(message) { return Boolean( - message.blocks?.find(({ appId }) => appId === 'videoconf-core')?.elements?.find(({ actionId }) => actionId === 'joinLivechat'), + message.blocks + ?.find(({ appId, type }) => appId === 'videoconf-core' && type === 'actions') + ?.elements?.find(({ actionId }) => actionId === 'joinLivechat'), ); } @@ -137,7 +139,7 @@ export class MessageList extends MemoizedComponent { } const videoConfJoinBlock = message.blocks - ?.find(({ appId }) => appId === 'videoconf-core') + ?.find(({ appId, type }) => appId === 'videoconf-core' && type === 'actions') ?.elements?.find(({ actionId }) => actionId === 'joinLivechat'); if (videoConfJoinBlock) { // If the call is not accepted yet, don't render the message. diff --git a/packages/livechat/src/lib/room.js b/packages/livechat/src/lib/room.js index 858df335671f2..3cfd8918234aa 100644 --- a/packages/livechat/src/lib/room.js +++ b/packages/livechat/src/lib/room.js @@ -35,7 +35,9 @@ export const closeChat = async ({ transcriptRequested } = {}) => { }; const getVideoConfMessageData = (message) => - message.blocks?.find(({ appId }) => appId === 'videoconf-core')?.elements?.find(({ actionId }) => actionId === 'joinLivechat'); + message.blocks + ?.find(({ appId, type }) => appId === 'videoconf-core' && type === 'actions') + ?.elements?.find(({ actionId }) => actionId === 'joinLivechat'); const isVideoCallMessage = (message) => { if (message.t === constants.webRTCCallStartedMessageType) { diff --git a/packages/model-typings/package.json b/packages/model-typings/package.json index 55516d3bb65cf..024d295148f97 100644 --- a/packages/model-typings/package.json +++ b/packages/model-typings/package.json @@ -5,7 +5,7 @@ "devDependencies": { "@types/jest": "^27.4.1", "@types/node-rsa": "^1.1.1", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "mongodb": "^4.3.1", "ts-jest": "^27.1.5", diff --git a/packages/model-typings/src/models/IMessagesModel.ts b/packages/model-typings/src/models/IMessagesModel.ts index c9d925165b6a3..fed76010e137e 100644 --- a/packages/model-typings/src/models/IMessagesModel.ts +++ b/packages/model-typings/src/models/IMessagesModel.ts @@ -48,8 +48,6 @@ export interface IMessagesModel extends IBaseModel { addBlocksById(_id: string, blocks: Required['blocks']): Promise; - removeVideoConfJoinButton(_id: IMessage['_id']): Promise; - countRoomsWithMessageType(type: IMessage['t'], options: AggregateOptions): Promise; countByType(type: IMessage['t'], options: CountDocumentsOptions): Promise; diff --git a/packages/model-typings/src/models/IVideoConferenceModel.ts b/packages/model-typings/src/models/IVideoConferenceModel.ts index d1cfbcd919bed..e0a1090eb5ca3 100644 --- a/packages/model-typings/src/models/IVideoConferenceModel.ts +++ b/packages/model-typings/src/models/IVideoConferenceModel.ts @@ -54,7 +54,7 @@ export interface IVideoConferenceModel extends IBaseModel { setProviderDataById(callId: string, providerData: Record | undefined): Promise; - addUserById(callId: string, user: Pick & { ts?: Date }): Promise; + addUserById(callId: string, user: Required> & { ts?: Date }): Promise; setMessageById(callId: string, messageType: keyof VideoConference['messages'], messageId: string): Promise; diff --git a/packages/models/package.json b/packages/models/package.json index 77846eb64251f..6c6773d02ce01 100644 --- a/packages/models/package.json +++ b/packages/models/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "@types/jest": "^27.4.1", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "ts-jest": "^27.1.5", "typescript": "~4.5.5" diff --git a/packages/node-poplib/package.json b/packages/node-poplib/package.json index eac15f26ef199..792fc9f6f30d1 100644 --- a/packages/node-poplib/package.json +++ b/packages/node-poplib/package.json @@ -4,7 +4,7 @@ "private": true, "devDependencies": { "@types/jest": "^27.4.1", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "ts-jest": "^27.1.4", "typescript": "~4.5.5" diff --git a/packages/rest-typings/package.json b/packages/rest-typings/package.json index f1484f8243203..4a5b6b4a8e8c2 100644 --- a/packages/rest-typings/package.json +++ b/packages/rest-typings/package.json @@ -5,7 +5,7 @@ "devDependencies": { "@rocket.chat/eslint-config": "workspace:^", "@types/jest": "^27.4.1", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "mongodb": "^4.3.1", "ts-jest": "^27.1.5", diff --git a/packages/ui-client/package.json b/packages/ui-client/package.json index ab4bfc9a98b08..39aaa9d9cb665 100644 --- a/packages/ui-client/package.json +++ b/packages/ui-client/package.json @@ -3,10 +3,11 @@ "version": "0.0.1", "private": true, "devDependencies": { - "@rocket.chat/css-in-js": "0.31.21", + "@babel/core": "~7.18.13", + "@rocket.chat/css-in-js": "next", "@rocket.chat/fuselage": "next", - "@rocket.chat/fuselage-hooks": "0.31.21", - "@rocket.chat/icons": "0.31.21", + "@rocket.chat/fuselage-hooks": "next", + "@rocket.chat/icons": "next", "@rocket.chat/ui-contexts": "workspace:~", "@storybook/addon-actions": "~6.5.10", "@storybook/addon-docs": "~6.5.10", @@ -18,10 +19,12 @@ "@storybook/manager-webpack4": "~6.5.10", "@storybook/react": "~6.5.10", "@storybook/testing-library": "~0.0.13", + "@types/babel__core": "^7", "@types/jest": "^27.4.1", "@types/postcss-url": "^10", - "@types/react": "~17.0.47", - "eslint": "^8.20.0", + "@types/react": "~17.0.48", + "@types/react-dom": "~17.0.17", + "eslint": "^8.22.0", "eslint-plugin-anti-trojan-source": "^1.1.0", "eslint-plugin-react": "^7.30.1", "eslint-plugin-react-hooks": "^4.6.0", @@ -56,6 +59,7 @@ "@rocket.chat/fuselage": "*", "@rocket.chat/fuselage-hooks": "*", "@rocket.chat/icons": "*", + "@rocket.chat/ui-contexts": "*", "react": "~17.0.2" } } diff --git a/packages/ui-contexts/package.json b/packages/ui-contexts/package.json index 7836fc75cca38..bfec0ce967c84 100644 --- a/packages/ui-contexts/package.json +++ b/packages/ui-contexts/package.json @@ -8,9 +8,10 @@ "@rocket.chat/fuselage-hooks": "0.31.21", "@rocket.chat/rest-typings": "workspace:^", "@types/jest": "^27.4.1", - "@types/react": "^17.0.47", + "@types/react": "~17.0.48", + "@types/react-dom": "~17.0.17", "@types/use-sync-external-store": "^0.0.3", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "jest": "^27.5.1", "mongodb": "^4.3.1", "react": "~17.0.2", diff --git a/packages/ui-video-conf/.eslintrc.json b/packages/ui-video-conf/.eslintrc.json index 1859ff825f630..07037ccf0bc8e 100644 --- a/packages/ui-video-conf/.eslintrc.json +++ b/packages/ui-video-conf/.eslintrc.json @@ -5,7 +5,8 @@ "@rocket.chat/eslint-config/original", "prettier", "plugin:anti-trojan-source/recommended", - "plugin:react/jsx-runtime" + "plugin:react/jsx-runtime", + "plugin:storybook/recommended" ], "parser": "@typescript-eslint/parser", "plugins": ["@typescript-eslint", "react", "react-hooks", "prettier"], @@ -63,5 +64,13 @@ "version": "detect" } }, - "ignorePatterns": ["**/dist"] + "ignorePatterns": ["**/dist"], + "overrides": [ + { + "files": ["*.stories.tsx"], + "rules": { + "react/no-multi-comp": "off" + } + } + ] } diff --git a/packages/ui-video-conf/.storybook/main.js b/packages/ui-video-conf/.storybook/main.js new file mode 100644 index 0000000000000..4b6ae93751aaa --- /dev/null +++ b/packages/ui-video-conf/.storybook/main.js @@ -0,0 +1,12 @@ +module.exports = { + "stories": [ + "../src/**/*.stories.mdx", + "../src/**/*.stories.@(js|jsx|ts|tsx)" + ], + "addons": [ + "@storybook/addon-links", + "@storybook/addon-essentials", + "@storybook/addon-interactions" + ], + "framework": "@storybook/react" +} diff --git a/packages/ui-video-conf/.storybook/preview.js b/packages/ui-video-conf/.storybook/preview.js new file mode 100644 index 0000000000000..abd704f795106 --- /dev/null +++ b/packages/ui-video-conf/.storybook/preview.js @@ -0,0 +1,25 @@ +import '../../../apps/meteor/app/theme/client/main.css'; +import 'highlight.js/styles/github.css'; + +export const parameters = { + actions: { argTypesRegex: "^on[A-Z].*" }, + controls: { + matchers: { + color: /(background|color)$/i, + date: /Date$/, + }, + }, +} + +export const decorators = [ + (Story) => ( +
+ + +
+ ) +]; diff --git a/packages/ui-video-conf/package.json b/packages/ui-video-conf/package.json index f9671464e13c1..b09a72beb1363 100644 --- a/packages/ui-video-conf/package.json +++ b/packages/ui-video-conf/package.json @@ -3,15 +3,27 @@ "version": "0.0.1", "private": true, "devDependencies": { - "@rocket.chat/css-in-js": "0.31.21", + "@babel/core": "~7.18.13", + "@rocket.chat/css-in-js": "next", "@rocket.chat/eslint-config": "workspace:^", "@rocket.chat/fuselage": "next", - "@rocket.chat/fuselage-hooks": "0.31.21", - "@rocket.chat/styled": "0.31.21", + "@rocket.chat/fuselage-hooks": "next", + "@rocket.chat/icons": "next", + "@rocket.chat/styled": "next", + "@rocket.chat/ui-contexts": "workspace:^", + "@storybook/addon-actions": "~6.5.10", + "@storybook/addon-docs": "~6.5.10", + "@storybook/addon-essentials": "~6.5.10", + "@storybook/builder-webpack4": "~6.5.10", + "@storybook/manager-webpack4": "~6.5.10", + "@storybook/react": "~6.5.10", + "@storybook/testing-library": "~0.0.13", + "@types/babel__core": "^7", "@types/jest": "^27.4.1", - "eslint": "^8.20.0", + "eslint": "^8.22.0", "eslint-plugin-react": "^7.30.1", "eslint-plugin-react-hooks": "^4.6.0", + "eslint-plugin-storybook": "^0.6.4", "jest": "^27.5.1", "ts-jest": "^27.1.4", "typescript": "~4.5.5" @@ -20,7 +32,9 @@ "@rocket.chat/css-in-js": "*", "@rocket.chat/fuselage": "*", "@rocket.chat/fuselage-hooks": "*", + "@rocket.chat/icons": "*", "@rocket.chat/styled": "*", + "@rocket.chat/ui-contexts": "*", "react": "^17.0.2", "react-dom": "^17.0.2" }, @@ -29,11 +43,15 @@ "eslint:fix": "eslint --ext .js,.jsx,.ts,.tsx . --fix", "jest": "jest", "build": "tsc -p tsconfig.json", + "storybook": "start-storybook -p 6006", "dev": "tsc -p tsconfig.json --watch --preserveWatchOutput" }, "main": "./dist/index.js", "typings": "./dist/index.d.ts", "files": [ "/dist" - ] + ], + "dependencies": { + "@rocket.chat/emitter": "next" + } } diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessage.stories.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessage.stories.tsx new file mode 100644 index 0000000000000..cdf6232d8363c --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessage.stories.tsx @@ -0,0 +1,122 @@ +import { MessageDivider, Message, Avatar, Box } from '@rocket.chat/fuselage'; +import type { ComponentMeta, ComponentStory } from '@storybook/react'; +import type { ReactElement } from 'react'; + +import '@rocket.chat/icons/dist/rocketchat.css'; +import { VideoConfMessage, VideoConfMessageIcon, VideoConfMessageRow, VideoConfMessageText } from '.'; +import VideoConfMessageAction from './VideoConfMessageAction'; +import VideoConfMessageActions from './VideoConfMessageActions'; +import VideoConfMessageButton from './VideoConfMessageButton'; +import VideoConfMessageContent from './VideoConfMessageContent'; +import VideoConfMessageFooter from './VideoConfMessageFooter'; +import VideoConfMessageFooterText from './VideoConfMessageFooterText'; +import VideoConfMessageSkeleton from './VideoConfMessageSkeleton'; +import VideoConfMessageUserStack from './VideoConfMessageUserStack'; + +export default { + title: 'Components/VideoConfMessage', + component: VideoConfMessage, + decorators: [ + (Story): ReactElement => ( + + May, 24, 2020 + + + + + + + Haylie George + @haylie.george + Admin + User + Owner + 12:00 PM + + + + + + + + ), + ], +} as ComponentMeta; + +const avatarUrl = + ''; + +export const CallingDM: ComponentStory = () => ( + + + + + Calling... + + + + + + + Join + Waiting for answer + + +); + +export const CallEndedDM: ComponentStory = () => ( + + + + + Call ended + + + + + + + Call Back + Call was not answered + + +); + +export const CallOngoing: ComponentStory = () => ( + + + + + Call ongoing + + + + + + + Join + + Joined + + +); + +export const CallEnded: ComponentStory = () => ( + + + + + Call ended + + + + + + + + Joined + + +); + +export const Loading: ComponentStory = () => ; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessage.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessage.tsx new file mode 100644 index 0000000000000..95300936aae0f --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessage.tsx @@ -0,0 +1,16 @@ +import { Box, Palette } from '@rocket.chat/fuselage'; +import type { ReactElement } from 'react'; + +const VideoConfMessage = ({ ...props }): ReactElement => ( + +); + +export default VideoConfMessage; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageAction.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageAction.tsx new file mode 100644 index 0000000000000..9b705001c03fa --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageAction.tsx @@ -0,0 +1,7 @@ +import { IconButton } from '@rocket.chat/fuselage'; +import type { ComponentProps, ReactElement } from 'react'; + +const VideoConfMessageAction = ({ icon = 'info', ...props }: ComponentProps): ReactElement => ( + +); +export default VideoConfMessageAction; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageActions.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageActions.tsx new file mode 100644 index 0000000000000..cc6112dfbd35f --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageActions.tsx @@ -0,0 +1,10 @@ +import { ButtonGroup } from '@rocket.chat/fuselage'; +import type { ComponentProps, ReactElement } from 'react'; + +const VideoConfMessageActions = ({ children, ...props }: ComponentProps): ReactElement => ( + + {children} + +); + +export default VideoConfMessageActions; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageButton.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageButton.tsx new file mode 100644 index 0000000000000..f67a87a00b3f6 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageButton.tsx @@ -0,0 +1,15 @@ +import { Box, Button } from '@rocket.chat/fuselage'; +import type { AllHTMLAttributes, ReactElement, ReactNode } from 'react'; + +const VideoConfMessageButton = ({ + children, + primary, + ...props +}: { children: ReactNode; primary?: boolean } & Omit, 'is'>): ReactElement => ( + + + +); +export default VideoConfMessageButton; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageContent.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageContent.tsx new file mode 100644 index 0000000000000..65bc643b6ae91 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageContent.tsx @@ -0,0 +1,6 @@ +import { Box } from '@rocket.chat/fuselage'; +import type { ReactElement } from 'react'; + +const VideoConfMessageContent = ({ ...props }): ReactElement => ; + +export default VideoConfMessageContent; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageFooter.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageFooter.tsx new file mode 100644 index 0000000000000..1adfc10820b01 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageFooter.tsx @@ -0,0 +1,14 @@ +import { Box } from '@rocket.chat/fuselage'; +import type { ReactElement, ReactNode } from 'react'; + +import VideoConfMessageRow from './VideoConfMessageRow'; + +const VideoConfMessageFooter = ({ children, ...props }: { children: ReactNode }): ReactElement => ( + + + {children} + + +); + +export default VideoConfMessageFooter; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageFooterText.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageFooterText.tsx new file mode 100644 index 0000000000000..975df374ff01d --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageFooterText.tsx @@ -0,0 +1,9 @@ +import { Box } from '@rocket.chat/fuselage'; +import type { ReactElement, ReactNode } from 'react'; + +const VideoConfMessageFooterText = ({ children }: { children: ReactNode }): ReactElement => ( + + {children} + +); +export default VideoConfMessageFooterText; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageIcon.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageIcon.tsx new file mode 100644 index 0000000000000..ab14f69f3610d --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageIcon.tsx @@ -0,0 +1,39 @@ +import { Box, Icon, Palette } from '@rocket.chat/fuselage'; +import type { ReactElement } from 'react'; + +type VideoConfMessageIconProps = { + variant?: keyof typeof styles; +}; + +const styles = { + ended: { + icon: 'phone-off', + color: Palette.text['font-hint'].toString(), + backgroundColor: Palette.surface['surface-neutral'].toString(), + }, + incoming: { + icon: 'phone-in', + color: Palette.statusColor['status-font-on-info'].toString(), + backgroundColor: Palette.status['status-background-info'].toString(), + }, + outgoing: { + icon: 'phone', + color: Palette.statusColor['status-font-on-success'].toString(), + backgroundColor: Palette.status['status-background-success'].toString(), + }, +} as const; + +const VideoConfMessageIcon = ({ variant = 'ended' }: VideoConfMessageIconProps): ReactElement => ( + + + +); + +export default VideoConfMessageIcon; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageRow.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageRow.tsx new file mode 100644 index 0000000000000..f13320dd9fdf3 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageRow.tsx @@ -0,0 +1,6 @@ +import { Box } from '@rocket.chat/fuselage'; +import type { ReactElement } from 'react'; + +const VideoConfMessageRow = ({ ...props }): ReactElement => ; + +export default VideoConfMessageRow; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageSkeleton.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageSkeleton.tsx new file mode 100644 index 0000000000000..1b90ca49cc65b --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageSkeleton.tsx @@ -0,0 +1,18 @@ +import { Skeleton } from '@rocket.chat/fuselage'; +import type { ReactElement } from 'react'; + +import VideoConfMessage from './VideoConfMessage'; +import VideoConfMessageRow from './VideoConfMessageRow'; + +const VideoConfMessageSkeleton = (): ReactElement => ( + + + + + + + + +); + +export default VideoConfMessageSkeleton; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageText.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageText.tsx new file mode 100644 index 0000000000000..d0cfc3eafced9 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageText.tsx @@ -0,0 +1,6 @@ +import { Box } from '@rocket.chat/fuselage'; +import type { ReactElement, ComponentProps } from 'react'; + +const VideoConfMessageText = ({ ...props }: ComponentProps): ReactElement => ; + +export default VideoConfMessageText; diff --git a/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageUserStack.tsx b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageUserStack.tsx new file mode 100644 index 0000000000000..2ca03a8140405 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/VideoConfMessageUserStack.tsx @@ -0,0 +1,24 @@ +import type { IVideoConferenceUser, Serialized } from '@rocket.chat/core-typings'; +import { Avatar, Box } from '@rocket.chat/fuselage'; +import { useUserAvatarPath } from '@rocket.chat/ui-contexts'; +import { ReactElement, memo } from 'react'; + +const MAX_USERS = 6; + +const VideoConfMessageUserStack = ({ users }: { users: Serialized[] }): ReactElement => { + const getUserAvatarPath = useUserAvatarPath(); + + return ( + + + {users.slice(0, MAX_USERS).map(({ username }, index) => ( + + + + ))} + + + ); +}; + +export default memo(VideoConfMessageUserStack); diff --git a/packages/ui-video-conf/src/VideoConfMessage/index.ts b/packages/ui-video-conf/src/VideoConfMessage/index.ts new file mode 100644 index 0000000000000..1e34514df1709 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfMessage/index.ts @@ -0,0 +1,27 @@ +import VideoConfMessage from './VideoConfMessage'; +import VideoConfMessageAction from './VideoConfMessageAction'; +import VideoConfMessageActions from './VideoConfMessageActions'; +import VideoConfMessageButton from './VideoConfMessageButton'; +import VideoConfMessageContent from './VideoConfMessageContent'; +import VideoConfMessageFooter from './VideoConfMessageFooter'; +import VideoConfMessageFooterText from './VideoConfMessageFooterText'; +import VideoConfMessageIcon from './VideoConfMessageIcon'; +import VideoConfMessageRow from './VideoConfMessageRow'; +import VideoConfMessageSkeleton from './VideoConfMessageSkeleton'; +import VideoConfMessageText from './VideoConfMessageText'; +import VideoConfMessageUserStack from './VideoConfMessageUserStack'; + +export { + VideoConfMessage, + VideoConfMessageIcon, + VideoConfMessageRow, + VideoConfMessageContent, + VideoConfMessageButton, + VideoConfMessageText, + VideoConfMessageSkeleton, + VideoConfMessageFooter, + VideoConfMessageAction, + VideoConfMessageActions, + VideoConfMessageUserStack, + VideoConfMessageFooterText, +}; diff --git a/packages/ui-video-conf/src/VideoConfPopup/VideoConfPopup.stories.tsx b/packages/ui-video-conf/src/VideoConfPopup/VideoConfPopup.stories.tsx new file mode 100644 index 0000000000000..4f73e3cf47758 --- /dev/null +++ b/packages/ui-video-conf/src/VideoConfPopup/VideoConfPopup.stories.tsx @@ -0,0 +1,57 @@ +import { Avatar, Icon } from '@rocket.chat/fuselage'; +import { action } from '@storybook/addon-actions'; +import type { ComponentMeta, ComponentStory } from '@storybook/react'; +import type { ReactElement } from 'react'; + +import '@rocket.chat/icons/dist/rocketchat.css'; +import { + VideoConfPopup, + VideoConfPopupHeader, + VideoConfPopupTitle, + VideoConfPopupControllers, + VideoConfPopupContent, + VideoConfPopupFooter, + VideoConfPopupFooterButtons, + VideoConfPopupInfo, + VideoConfPopupBackdrop, +} from '.'; +import { VideoConfController, VideoConfButton } from '..'; + +export default { + title: 'Components/VideoConfPopup', + component: VideoConfPopup, + decorators: [ + (Story): ReactElement => ( + + + + ), + ], +} as ComponentMeta; + +const avatarUrl = + ''; + +export const StartCall: ComponentStory = () => ( + + + + + + + + + + } icon={}> + Room Name + + + + + + Start Call + + + + +); diff --git a/packages/ui-video-conf/src/index.ts b/packages/ui-video-conf/src/index.ts index e7244b55b214a..d331731d0f44c 100644 --- a/packages/ui-video-conf/src/index.ts +++ b/packages/ui-video-conf/src/index.ts @@ -1,6 +1,7 @@ import VideoConfButton from './VideoConfButton'; import VideoConfController from './VideoConfController'; +export * from './VideoConfMessage'; export * from './VideoConfPopup'; export * from './hooks'; export { VideoConfButton, VideoConfController }; diff --git a/packages/web-ui-registration/package.json b/packages/web-ui-registration/package.json index 6d8a378ee655b..e331825f18189 100644 --- a/packages/web-ui-registration/package.json +++ b/packages/web-ui-registration/package.json @@ -5,7 +5,7 @@ "devDependencies": { "@rocket.chat/layout": "next", "@rocket.chat/ui-contexts": "workspace:^", - "@tanstack/react-query": "^4.2.3", + "@tanstack/react-query": "^4.16.1", "@testing-library/react": "^13.3.0", "@types/jest": "^27.4.1", "eslint": "^8.12.0", diff --git a/yarn.lock b/yarn.lock index df92857d2820f..74109b25d8e6f 100644 --- a/yarn.lock +++ b/yarn.lock @@ -60,6 +60,13 @@ __metadata: languageName: node linkType: hard +"@babel/compat-data@npm:^7.20.0, @babel/compat-data@npm:^7.20.1": + version: 7.20.1 + resolution: "@babel/compat-data@npm:7.20.1" + checksum: 989b9b7a6fe43c547bb8329241bd0ba6983488b83d29cc59de35536272ee6bb4cc7487ba6c8a4bceebb3a57f8c5fea1434f80bbbe75202bc79bc1110f955ff25 + languageName: node + linkType: hard + "@babel/core@npm:7.12.9": version: 7.12.9 resolution: "@babel/core@npm:7.12.9" @@ -84,7 +91,7 @@ __metadata: languageName: node linkType: hard -"@babel/core@npm:^7.1.0, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.10, @babel/core@npm:^7.12.3, @babel/core@npm:^7.18.9, @babel/core@npm:^7.19.1, @babel/core@npm:^7.7.2, @babel/core@npm:^7.7.5, @babel/core@npm:^7.8.0": +"@babel/core@npm:^7.1.0, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.10, @babel/core@npm:^7.12.3, @babel/core@npm:^7.19.1, @babel/core@npm:^7.7.2, @babel/core@npm:^7.7.5, @babel/core@npm:^7.8.0": version: 7.19.1 resolution: "@babel/core@npm:7.19.1" dependencies: @@ -107,6 +114,29 @@ __metadata: languageName: node linkType: hard +"@babel/core@npm:^7.18.13": + version: 7.20.2 + resolution: "@babel/core@npm:7.20.2" + dependencies: + "@ampproject/remapping": ^2.1.0 + "@babel/code-frame": ^7.18.6 + "@babel/generator": ^7.20.2 + "@babel/helper-compilation-targets": ^7.20.0 + "@babel/helper-module-transforms": ^7.20.2 + "@babel/helpers": ^7.20.1 + "@babel/parser": ^7.20.2 + "@babel/template": ^7.18.10 + "@babel/traverse": ^7.20.1 + "@babel/types": ^7.20.2 + convert-source-map: ^1.7.0 + debug: ^4.1.0 + gensync: ^1.0.0-beta.2 + json5: ^2.2.1 + semver: ^6.3.0 + checksum: 98faaaef26103a276a30a141b951a93bc8418d100d1f668bf7a69d12f3e25df57958e8b6b9100d95663f720db62da85ade736f6629a5ebb1e640251a1b43c0e4 + languageName: node + linkType: hard + "@babel/core@npm:~7.18.13": version: 7.18.13 resolution: "@babel/core@npm:7.18.13" @@ -155,6 +185,17 @@ __metadata: languageName: node linkType: hard +"@babel/generator@npm:^7.20.1, @babel/generator@npm:^7.20.2": + version: 7.20.4 + resolution: "@babel/generator@npm:7.20.4" + dependencies: + "@babel/types": ^7.20.2 + "@jridgewell/gen-mapping": ^0.3.2 + jsesc: ^2.5.1 + checksum: 967b59f18e5ce999e5a741825bcecb2be4bbfc1824a92c21b47d0b5694e0eb09314a70f8b9142e9591c149c7fb83d51f73ae8fbd96d30a42666425889e51ceb1 + languageName: node + linkType: hard + "@babel/helper-annotate-as-pure@npm:^7.18.6": version: 7.18.6 resolution: "@babel/helper-annotate-as-pure@npm:7.18.6" @@ -188,6 +229,20 @@ __metadata: languageName: node linkType: hard +"@babel/helper-compilation-targets@npm:^7.20.0": + version: 7.20.0 + resolution: "@babel/helper-compilation-targets@npm:7.20.0" + dependencies: + "@babel/compat-data": ^7.20.0 + "@babel/helper-validator-option": ^7.18.6 + browserslist: ^4.21.3 + semver: ^6.3.0 + peerDependencies: + "@babel/core": ^7.0.0 + checksum: bc183f2109648849c8fde0b3c5cf08adf2f7ad6dc617b546fd20f34c8ef574ee5ee293c8d1bd0ed0221212e8f5907cdc2c42097870f1dcc769a654107d82c95b + languageName: node + linkType: hard + "@babel/helper-create-class-features-plugin@npm:^7.17.6, @babel/helper-create-class-features-plugin@npm:^7.18.6, @babel/helper-create-class-features-plugin@npm:^7.19.0": version: 7.19.0 resolution: "@babel/helper-create-class-features-plugin@npm:7.19.0" @@ -320,6 +375,22 @@ __metadata: languageName: node linkType: hard +"@babel/helper-module-transforms@npm:^7.19.6, @babel/helper-module-transforms@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/helper-module-transforms@npm:7.20.2" + dependencies: + "@babel/helper-environment-visitor": ^7.18.9 + "@babel/helper-module-imports": ^7.18.6 + "@babel/helper-simple-access": ^7.20.2 + "@babel/helper-split-export-declaration": ^7.18.6 + "@babel/helper-validator-identifier": ^7.19.1 + "@babel/template": ^7.18.10 + "@babel/traverse": ^7.20.1 + "@babel/types": ^7.20.2 + checksum: 33a60ca115f6fce2c9d98e2a2e5649498aa7b23e2ae3c18745d7a021487708fc311458c33542f299387a0da168afccba94116e077f2cce49ae9e5ab83399e8a2 + languageName: node + linkType: hard + "@babel/helper-optimise-call-expression@npm:^7.18.6": version: 7.18.6 resolution: "@babel/helper-optimise-call-expression@npm:7.18.6" @@ -343,6 +414,13 @@ __metadata: languageName: node linkType: hard +"@babel/helper-plugin-utils@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/helper-plugin-utils@npm:7.20.2" + checksum: f6cae53b7fdb1bf3abd50fa61b10b4470985b400cc794d92635da1e7077bb19729f626adc0741b69403d9b6e411cddddb9c0157a709cc7c4eeb41e663be5d74b + languageName: node + linkType: hard + "@babel/helper-remap-async-to-generator@npm:^7.18.6, @babel/helper-remap-async-to-generator@npm:^7.18.9": version: 7.18.9 resolution: "@babel/helper-remap-async-to-generator@npm:7.18.9" @@ -370,6 +448,19 @@ __metadata: languageName: node linkType: hard +"@babel/helper-replace-supers@npm:^7.19.1": + version: 7.19.1 + resolution: "@babel/helper-replace-supers@npm:7.19.1" + dependencies: + "@babel/helper-environment-visitor": ^7.18.9 + "@babel/helper-member-expression-to-functions": ^7.18.9 + "@babel/helper-optimise-call-expression": ^7.18.6 + "@babel/traverse": ^7.19.1 + "@babel/types": ^7.19.0 + checksum: a0e4bf79ebe7d2bb5947169e47a0b4439c73fb0ec57d446cf3ea81b736721129ec373c3f94d2ebd2716b26dd65f8e6c083dac898170d42905e7ba815a2f52c25 + languageName: node + linkType: hard + "@babel/helper-simple-access@npm:^7.18.6": version: 7.18.6 resolution: "@babel/helper-simple-access@npm:7.18.6" @@ -379,6 +470,15 @@ __metadata: languageName: node linkType: hard +"@babel/helper-simple-access@npm:^7.19.4, @babel/helper-simple-access@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/helper-simple-access@npm:7.20.2" + dependencies: + "@babel/types": ^7.20.2 + checksum: ad1e96ee2e5f654ffee2369a586e5e8d2722bf2d8b028a121b4c33ebae47253f64d420157b9f0a8927aea3a9e0f18c0103e74fdd531815cf3650a0a4adca11a1 + languageName: node + linkType: hard + "@babel/helper-skip-transparent-expression-wrappers@npm:^7.18.9": version: 7.18.9 resolution: "@babel/helper-skip-transparent-expression-wrappers@npm:7.18.9" @@ -404,6 +504,13 @@ __metadata: languageName: node linkType: hard +"@babel/helper-string-parser@npm:^7.19.4": + version: 7.19.4 + resolution: "@babel/helper-string-parser@npm:7.19.4" + checksum: b2f8a3920b30dfac81ec282ac4ad9598ea170648f8254b10f475abe6d944808fb006aab325d3eb5a8ad3bea8dfa888cfa6ef471050dae5748497c110ec060943 + languageName: node + linkType: hard + "@babel/helper-validator-identifier@npm:^7.18.6": version: 7.18.6 resolution: "@babel/helper-validator-identifier@npm:7.18.6" @@ -411,6 +518,13 @@ __metadata: languageName: node linkType: hard +"@babel/helper-validator-identifier@npm:^7.19.1": + version: 7.19.1 + resolution: "@babel/helper-validator-identifier@npm:7.19.1" + checksum: 0eca5e86a729162af569b46c6c41a63e18b43dbe09fda1d2a3c8924f7d617116af39cac5e4cd5d431bb760b4dca3c0970e0c444789b1db42bcf1fa41fbad0a3a + languageName: node + linkType: hard + "@babel/helper-validator-option@npm:^7.16.7, @babel/helper-validator-option@npm:^7.18.6": version: 7.18.6 resolution: "@babel/helper-validator-option@npm:7.18.6" @@ -441,6 +555,17 @@ __metadata: languageName: node linkType: hard +"@babel/helpers@npm:^7.20.1": + version: 7.20.1 + resolution: "@babel/helpers@npm:7.20.1" + dependencies: + "@babel/template": ^7.18.10 + "@babel/traverse": ^7.20.1 + "@babel/types": ^7.20.0 + checksum: be35f78666bdab895775ed94dbeb098f7b4fa08ce4cfb0c3a9e69b7220cce56960dcdc2b14f5df9d3b80388d4bf7df155c97f6cf6768c0138f4e6931d0f44955 + languageName: node + linkType: hard + "@babel/highlight@npm:^7.10.4, @babel/highlight@npm:^7.18.6": version: 7.18.6 resolution: "@babel/highlight@npm:7.18.6" @@ -461,6 +586,15 @@ __metadata: languageName: node linkType: hard +"@babel/parser@npm:^7.20.1, @babel/parser@npm:^7.20.2": + version: 7.20.3 + resolution: "@babel/parser@npm:7.20.3" + bin: + parser: ./bin/babel-parser.js + checksum: 33bcdb45de65a3cf27ed376cb34f32be3c3485a10e3252f8d0126f6a034efc3145c0d219e57fcd5a8956361552008bc30b9bae4a723823fb3633027071be8a45 + languageName: node + linkType: hard + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@npm:^7.18.6": version: 7.18.6 resolution: "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@npm:7.18.6" @@ -499,6 +633,20 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-proposal-async-generator-functions@npm:^7.20.1": + version: 7.20.1 + resolution: "@babel/plugin-proposal-async-generator-functions@npm:7.20.1" + dependencies: + "@babel/helper-environment-visitor": ^7.18.9 + "@babel/helper-plugin-utils": ^7.19.0 + "@babel/helper-remap-async-to-generator": ^7.18.9 + "@babel/plugin-syntax-async-generators": ^7.8.4 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 518483a68c5618932109913eb7316ed5e656c575cbd9d22667bc0451e35a1be45f8eaeb8e2065834b36c8a93c4840f78cebf8f1d067b07c422f7be16d58eca60 + languageName: node + linkType: hard + "@babel/plugin-proposal-class-properties@npm:^7.12.1, @babel/plugin-proposal-class-properties@npm:^7.18.6": version: 7.18.6 resolution: "@babel/plugin-proposal-class-properties@npm:7.18.6" @@ -651,6 +799,21 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-proposal-object-rest-spread@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/plugin-proposal-object-rest-spread@npm:7.20.2" + dependencies: + "@babel/compat-data": ^7.20.1 + "@babel/helper-compilation-targets": ^7.20.0 + "@babel/helper-plugin-utils": ^7.20.2 + "@babel/plugin-syntax-object-rest-spread": ^7.8.3 + "@babel/plugin-transform-parameters": ^7.20.1 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 9764d1a4735fcd384fdb9b6c6ccb20d1bea2f88f648640d26ce5d9cd5880ce1e389d2f852d7bea7e86ff343726225dc16e1deb92c7b3dc5c5721ed905a602318 + languageName: node + linkType: hard + "@babel/plugin-proposal-optional-catch-binding@npm:^7.18.6": version: 7.18.6 resolution: "@babel/plugin-proposal-optional-catch-binding@npm:7.18.6" @@ -824,6 +987,17 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-syntax-import-assertions@npm:^7.20.0": + version: 7.20.0 + resolution: "@babel/plugin-syntax-import-assertions@npm:7.20.0" + dependencies: + "@babel/helper-plugin-utils": ^7.19.0 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 6a86220e0aae40164cd3ffaf80e7c076a1be02a8f3480455dddbae05fda8140f429290027604df7a11b3f3f124866e8a6d69dbfa1dda61ee7377b920ad144d5b + languageName: node + linkType: hard + "@babel/plugin-syntax-import-meta@npm:^7.8.3": version: 7.10.4 resolution: "@babel/plugin-syntax-import-meta@npm:7.10.4" @@ -1013,6 +1187,17 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-transform-block-scoping@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/plugin-transform-block-scoping@npm:7.20.2" + dependencies: + "@babel/helper-plugin-utils": ^7.20.2 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 550b983277557ecfa3ef1e7a2367eaa9e0616a56f0d4106812cbc8aeca057b0f0b8bbc5c548b9b3b57399868f916e89e17303c802c8c46d18fba5bc174d4e794 + languageName: node + linkType: hard + "@babel/plugin-transform-classes@npm:^7.12.1, @babel/plugin-transform-classes@npm:^7.19.0": version: 7.19.0 resolution: "@babel/plugin-transform-classes@npm:7.19.0" @@ -1032,6 +1217,25 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-transform-classes@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/plugin-transform-classes@npm:7.20.2" + dependencies: + "@babel/helper-annotate-as-pure": ^7.18.6 + "@babel/helper-compilation-targets": ^7.20.0 + "@babel/helper-environment-visitor": ^7.18.9 + "@babel/helper-function-name": ^7.19.0 + "@babel/helper-optimise-call-expression": ^7.18.6 + "@babel/helper-plugin-utils": ^7.20.2 + "@babel/helper-replace-supers": ^7.19.1 + "@babel/helper-split-export-declaration": ^7.18.6 + globals: ^11.1.0 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 57f3467a8eb7853cdb61cda963cfb6c6568ad276d77c9de2ff5a2194650010217aa318ef3733975537c6fb906b73a019afb6ea650b01852e7d2e1fab4034361b + languageName: node + linkType: hard + "@babel/plugin-transform-computed-properties@npm:^7.18.9": version: 7.18.9 resolution: "@babel/plugin-transform-computed-properties@npm:7.18.9" @@ -1054,6 +1258,17 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-transform-destructuring@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/plugin-transform-destructuring@npm:7.20.2" + dependencies: + "@babel/helper-plugin-utils": ^7.20.2 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 09033e09b28ca1b0d46a8d82f5a677b1d718a739b3c199886908c3ef1af23369317d0c429b21507d480ee82721c15892a9893be18e50ad6fc219e69312f4b097 + languageName: node + linkType: hard + "@babel/plugin-transform-dotall-regex@npm:^7.18.6, @babel/plugin-transform-dotall-regex@npm:^7.4.4": version: 7.18.6 resolution: "@babel/plugin-transform-dotall-regex@npm:7.18.6" @@ -1160,6 +1375,18 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-transform-modules-amd@npm:^7.19.6": + version: 7.19.6 + resolution: "@babel/plugin-transform-modules-amd@npm:7.19.6" + dependencies: + "@babel/helper-module-transforms": ^7.19.6 + "@babel/helper-plugin-utils": ^7.19.0 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 4236aad970025bc10c772c1589b1e2eab8b7681933bb5ffa6e395d4c1a52532b28c47c553e3011b4272ea81e5ab39fe969eb5349584e8390e59771055c467d42 + languageName: node + linkType: hard + "@babel/plugin-transform-modules-commonjs@npm:^7.18.6": version: 7.18.6 resolution: "@babel/plugin-transform-modules-commonjs@npm:7.18.6" @@ -1174,6 +1401,19 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-transform-modules-commonjs@npm:^7.19.6": + version: 7.19.6 + resolution: "@babel/plugin-transform-modules-commonjs@npm:7.19.6" + dependencies: + "@babel/helper-module-transforms": ^7.19.6 + "@babel/helper-plugin-utils": ^7.19.0 + "@babel/helper-simple-access": ^7.19.4 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 85d46945ab5ba3fff89e962d560a5d40253f228b9659a697683db3de07c0236e8cd60e5eb41958007359951a42bc268bf32350fcdb5b4a86f58dff1e032c096e + languageName: node + linkType: hard + "@babel/plugin-transform-modules-systemjs@npm:^7.19.0": version: 7.19.0 resolution: "@babel/plugin-transform-modules-systemjs@npm:7.19.0" @@ -1189,6 +1429,20 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-transform-modules-systemjs@npm:^7.19.6": + version: 7.19.6 + resolution: "@babel/plugin-transform-modules-systemjs@npm:7.19.6" + dependencies: + "@babel/helper-hoist-variables": ^7.18.6 + "@babel/helper-module-transforms": ^7.19.6 + "@babel/helper-plugin-utils": ^7.19.0 + "@babel/helper-validator-identifier": ^7.19.1 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 8526431cc81ea3eb232ad50862d0ed1cbb422b5251d14a8d6610d0ca0617f6e75f35179e98eb1235d0cccb980120350b9f112594e5646dd45378d41eaaf87342 + languageName: node + linkType: hard + "@babel/plugin-transform-modules-umd@npm:^7.18.6": version: 7.18.6 resolution: "@babel/plugin-transform-modules-umd@npm:7.18.6" @@ -1247,6 +1501,17 @@ __metadata: languageName: node linkType: hard +"@babel/plugin-transform-parameters@npm:^7.20.1": + version: 7.20.3 + resolution: "@babel/plugin-transform-parameters@npm:7.20.3" + dependencies: + "@babel/helper-plugin-utils": ^7.20.2 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: 69054c93d744574e06b0244623140718ecba87e1cc34bd5c7bd5824fd4dbef764ac4832046ea1ba5d2c6a2f12e03289555c9f65f0aafae4871f3d740ff61b9ec + languageName: node + linkType: hard + "@babel/plugin-transform-property-literals@npm:^7.18.6": version: 7.18.6 resolution: "@babel/plugin-transform-property-literals@npm:7.18.6" @@ -1422,7 +1687,7 @@ __metadata: languageName: node linkType: hard -"@babel/preset-env@npm:^7.12.11, @babel/preset-env@npm:^7.18.9, @babel/preset-env@npm:^7.19.1": +"@babel/preset-env@npm:^7.12.11, @babel/preset-env@npm:^7.19.1": version: 7.19.1 resolution: "@babel/preset-env@npm:7.19.1" dependencies: @@ -1507,6 +1772,91 @@ __metadata: languageName: node linkType: hard +"@babel/preset-env@npm:^7.18.10": + version: 7.20.2 + resolution: "@babel/preset-env@npm:7.20.2" + dependencies: + "@babel/compat-data": ^7.20.1 + "@babel/helper-compilation-targets": ^7.20.0 + "@babel/helper-plugin-utils": ^7.20.2 + "@babel/helper-validator-option": ^7.18.6 + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": ^7.18.6 + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": ^7.18.9 + "@babel/plugin-proposal-async-generator-functions": ^7.20.1 + "@babel/plugin-proposal-class-properties": ^7.18.6 + "@babel/plugin-proposal-class-static-block": ^7.18.6 + "@babel/plugin-proposal-dynamic-import": ^7.18.6 + "@babel/plugin-proposal-export-namespace-from": ^7.18.9 + "@babel/plugin-proposal-json-strings": ^7.18.6 + "@babel/plugin-proposal-logical-assignment-operators": ^7.18.9 + "@babel/plugin-proposal-nullish-coalescing-operator": ^7.18.6 + "@babel/plugin-proposal-numeric-separator": ^7.18.6 + "@babel/plugin-proposal-object-rest-spread": ^7.20.2 + "@babel/plugin-proposal-optional-catch-binding": ^7.18.6 + "@babel/plugin-proposal-optional-chaining": ^7.18.9 + "@babel/plugin-proposal-private-methods": ^7.18.6 + "@babel/plugin-proposal-private-property-in-object": ^7.18.6 + "@babel/plugin-proposal-unicode-property-regex": ^7.18.6 + "@babel/plugin-syntax-async-generators": ^7.8.4 + "@babel/plugin-syntax-class-properties": ^7.12.13 + "@babel/plugin-syntax-class-static-block": ^7.14.5 + "@babel/plugin-syntax-dynamic-import": ^7.8.3 + "@babel/plugin-syntax-export-namespace-from": ^7.8.3 + "@babel/plugin-syntax-import-assertions": ^7.20.0 + "@babel/plugin-syntax-json-strings": ^7.8.3 + "@babel/plugin-syntax-logical-assignment-operators": ^7.10.4 + "@babel/plugin-syntax-nullish-coalescing-operator": ^7.8.3 + "@babel/plugin-syntax-numeric-separator": ^7.10.4 + "@babel/plugin-syntax-object-rest-spread": ^7.8.3 + "@babel/plugin-syntax-optional-catch-binding": ^7.8.3 + "@babel/plugin-syntax-optional-chaining": ^7.8.3 + "@babel/plugin-syntax-private-property-in-object": ^7.14.5 + "@babel/plugin-syntax-top-level-await": ^7.14.5 + "@babel/plugin-transform-arrow-functions": ^7.18.6 + "@babel/plugin-transform-async-to-generator": ^7.18.6 + "@babel/plugin-transform-block-scoped-functions": ^7.18.6 + "@babel/plugin-transform-block-scoping": ^7.20.2 + "@babel/plugin-transform-classes": ^7.20.2 + "@babel/plugin-transform-computed-properties": ^7.18.9 + "@babel/plugin-transform-destructuring": ^7.20.2 + "@babel/plugin-transform-dotall-regex": ^7.18.6 + "@babel/plugin-transform-duplicate-keys": ^7.18.9 + "@babel/plugin-transform-exponentiation-operator": ^7.18.6 + "@babel/plugin-transform-for-of": ^7.18.8 + "@babel/plugin-transform-function-name": ^7.18.9 + "@babel/plugin-transform-literals": ^7.18.9 + "@babel/plugin-transform-member-expression-literals": ^7.18.6 + "@babel/plugin-transform-modules-amd": ^7.19.6 + "@babel/plugin-transform-modules-commonjs": ^7.19.6 + "@babel/plugin-transform-modules-systemjs": ^7.19.6 + "@babel/plugin-transform-modules-umd": ^7.18.6 + "@babel/plugin-transform-named-capturing-groups-regex": ^7.19.1 + "@babel/plugin-transform-new-target": ^7.18.6 + "@babel/plugin-transform-object-super": ^7.18.6 + "@babel/plugin-transform-parameters": ^7.20.1 + "@babel/plugin-transform-property-literals": ^7.18.6 + "@babel/plugin-transform-regenerator": ^7.18.6 + "@babel/plugin-transform-reserved-words": ^7.18.6 + "@babel/plugin-transform-shorthand-properties": ^7.18.6 + "@babel/plugin-transform-spread": ^7.19.0 + "@babel/plugin-transform-sticky-regex": ^7.18.6 + "@babel/plugin-transform-template-literals": ^7.18.9 + "@babel/plugin-transform-typeof-symbol": ^7.18.9 + "@babel/plugin-transform-unicode-escapes": ^7.18.10 + "@babel/plugin-transform-unicode-regex": ^7.18.6 + "@babel/preset-modules": ^0.1.5 + "@babel/types": ^7.20.2 + babel-plugin-polyfill-corejs2: ^0.3.3 + babel-plugin-polyfill-corejs3: ^0.6.0 + babel-plugin-polyfill-regenerator: ^0.4.1 + core-js-compat: ^3.25.1 + semver: ^6.3.0 + peerDependencies: + "@babel/core": ^7.0.0-0 + checksum: ece2d7e9c7789db6116e962b8e1a55eb55c110c44c217f0c8f6ffea4ca234954e66557f7bd019b7affadf7fbb3a53ccc807e93fc935aacd48146234b73b6947e + languageName: node + linkType: hard + "@babel/preset-flow@npm:^7.12.1": version: 7.16.7 resolution: "@babel/preset-flow@npm:7.16.7" @@ -1635,6 +1985,24 @@ __metadata: languageName: node linkType: hard +"@babel/traverse@npm:^7.20.1": + version: 7.20.1 + resolution: "@babel/traverse@npm:7.20.1" + dependencies: + "@babel/code-frame": ^7.18.6 + "@babel/generator": ^7.20.1 + "@babel/helper-environment-visitor": ^7.18.9 + "@babel/helper-function-name": ^7.19.0 + "@babel/helper-hoist-variables": ^7.18.6 + "@babel/helper-split-export-declaration": ^7.18.6 + "@babel/parser": ^7.20.1 + "@babel/types": ^7.20.0 + debug: ^4.1.0 + globals: ^11.1.0 + checksum: 6696176d574b7ff93466848010bc7e94b250169379ec2a84f1b10da46a7cc2018ea5e3a520c3078487db51e3a4afab9ecff48f25d1dbad8c1319362f4148fb4b + languageName: node + linkType: hard + "@babel/types@npm:^7.0.0, @babel/types@npm:^7.12.11, @babel/types@npm:^7.12.7, @babel/types@npm:^7.18.10, @babel/types@npm:^7.18.13, @babel/types@npm:^7.18.6, @babel/types@npm:^7.18.9, @babel/types@npm:^7.19.0, @babel/types@npm:^7.2.0, @babel/types@npm:^7.3.0, @babel/types@npm:^7.3.3, @babel/types@npm:^7.4.4, @babel/types@npm:^7.8.3": version: 7.19.0 resolution: "@babel/types@npm:7.19.0" @@ -1646,6 +2014,17 @@ __metadata: languageName: node linkType: hard +"@babel/types@npm:^7.20.0, @babel/types@npm:^7.20.2": + version: 7.20.2 + resolution: "@babel/types@npm:7.20.2" + dependencies: + "@babel/helper-string-parser": ^7.19.4 + "@babel/helper-validator-identifier": ^7.19.1 + to-fast-properties: ^2.0.0 + checksum: 57e76e5f21876135f481bfd4010c87f2d38196bb0a2bc60a28d6e55e3afa90cdd9accf164e4cb71bdfb620517fa0a0cb5600cdce36c21d59fdaccfbb899c024c + languageName: node + linkType: hard + "@base2/pretty-print-object@npm:1.0.1": version: 1.0.1 resolution: "@base2/pretty-print-object@npm:1.0.1" @@ -1996,9 +2375,9 @@ __metadata: languageName: node linkType: hard -"@eslint/eslintrc@npm:^1.0.5, @eslint/eslintrc@npm:^1.3.2": - version: 1.3.2 - resolution: "@eslint/eslintrc@npm:1.3.2" +"@eslint/eslintrc@npm:^1.3.0": + version: 1.3.3 + resolution: "@eslint/eslintrc@npm:1.3.3" dependencies: ajv: ^6.12.4 debug: ^4.3.2 @@ -2009,7 +2388,7 @@ __metadata: js-yaml: ^4.1.0 minimatch: ^3.1.2 strip-json-comments: ^3.1.1 - checksum: 2074dca47d7e1c5c6323ff353f690f4b25d3ab53fe7d27337e2592d37a894cf60ca0e85ca66b50ff2db0bc7e630cc1e9c7347d65bb185b61416565584c38999c + checksum: f03e9d6727efd3e0719da2051ea80c0c73d20e28c171121527dbb868cd34232ca9c1d0525a66e517a404afea26624b1e47895b6a92474678418c2f50c9566694 languageName: node linkType: hard @@ -2030,6 +2409,23 @@ __metadata: languageName: node linkType: hard +"@eslint/eslintrc@npm:^1.3.2": + version: 1.3.2 + resolution: "@eslint/eslintrc@npm:1.3.2" + dependencies: + ajv: ^6.12.4 + debug: ^4.3.2 + espree: ^9.4.0 + globals: ^13.15.0 + ignore: ^5.2.0 + import-fresh: ^3.2.1 + js-yaml: ^4.1.0 + minimatch: ^3.1.2 + strip-json-comments: ^3.1.1 + checksum: 2074dca47d7e1c5c6323ff353f690f4b25d3ab53fe7d27337e2592d37a894cf60ca0e85ca66b50ff2db0bc7e630cc1e9c7347d65bb185b61416565584c38999c + languageName: node + linkType: hard + "@faker-js/faker@npm:^6.3.1": version: 6.3.1 resolution: "@faker-js/faker@npm:6.3.1" @@ -2181,17 +2577,6 @@ __metadata: languageName: node linkType: hard -"@humanwhocodes/config-array@npm:^0.9.2": - version: 0.9.5 - resolution: "@humanwhocodes/config-array@npm:0.9.5" - dependencies: - "@humanwhocodes/object-schema": ^1.2.1 - debug: ^4.1.1 - minimatch: ^3.0.4 - checksum: 8ba6281bc0590f6c6eadeefc14244b5a3e3f5903445aadd1a32099ed80e753037674026ce1b3c945ab93561bea5eb29e3c5bff67060e230c295595ba517a3492 - languageName: node - linkType: hard - "@humanwhocodes/gitignore-to-minimatch@npm:^1.0.2": version: 1.0.2 resolution: "@humanwhocodes/gitignore-to-minimatch@npm:1.0.2" @@ -5398,7 +5783,7 @@ __metadata: cron: ~1.8.0 date.js: ~0.3.3 debug: ~4.1.1 - eslint: ^8.20.0 + eslint: ^8.22.0 human-interval: ^2.0.0 jest: ^27.5.1 moment-timezone: ~0.5.27 @@ -5416,7 +5801,7 @@ __metadata: "@rocket.chat/rest-typings": "workspace:^" "@types/jest": ^27.4.1 "@types/strict-uri-encode": ^2.0.0 - eslint: ^8.20.0 + eslint: ^8.22.0 filter-obj: ^3.0.0 jest: ^27.5.1 query-string: ^7.1.1 @@ -5427,7 +5812,22 @@ __metadata: languageName: unknown linkType: soft -"@rocket.chat/apps-engine@npm:^1.32.0, @rocket.chat/apps-engine@npm:latest": +"@rocket.chat/apps-engine@npm:1.36.0-videoconf": + version: 1.36.0-videoconf + resolution: "@rocket.chat/apps-engine@npm:1.36.0-videoconf" + dependencies: + adm-zip: ^0.5.9 + cryptiles: ^4.1.3 + lodash.clonedeep: ^4.5.0 + semver: ^5.7.1 + stack-trace: 0.0.10 + uuid: ^3.4.0 + vm2: ^3.9.11 + checksum: 0d22a3e114f14823d8e372119de86bb88924a36392dee611ae880ba44d546c17e2e091527fc24c9c59d5a6199203480dff1f76cda73bbd9ffe69eccce4955276 + languageName: node + linkType: hard + +"@rocket.chat/apps-engine@npm:^1.32.0": version: 1.35.0 resolution: "@rocket.chat/apps-engine@npm:1.35.0" dependencies: @@ -5491,7 +5891,7 @@ __metadata: dependencies: "@types/jest": ^27.4.1 cheerio: 1.0.0-rc.10 - eslint: ^8.20.0 + eslint: ^8.22.0 jest: ^27.5.1 ts-jest: ^27.1.4 typescript: ~4.5.5 @@ -5507,7 +5907,7 @@ __metadata: "@rocket.chat/icons": 0.31.21 "@rocket.chat/message-parser": next "@rocket.chat/ui-kit": 0.31.21 - eslint: ^8.20.0 + eslint: ^8.22.0 mongodb: ^4.3.1 prettier: ^2.7.1 typescript: ~4.5.5 @@ -5527,7 +5927,7 @@ __metadata: languageName: node linkType: hard -"@rocket.chat/css-in-js@npm:~0.31.22-dev.19": +"@rocket.chat/css-in-js@npm:next, @rocket.chat/css-in-js@npm:~0.31.22-dev.19": version: 0.31.22-dev.19 resolution: "@rocket.chat/css-in-js@npm:0.31.22-dev.19" dependencies: @@ -5580,7 +5980,7 @@ __metadata: "@types/ws": ^8.5.3 colorette: ^1.4.0 ejson: ^2.2.2 - eslint: ^8.21.0 + eslint: ^8.22.0 eventemitter3: ^4.0.7 fibers: ^5.0.3 jaeger-client: ^3.19.0 @@ -5606,6 +6006,13 @@ __metadata: languageName: node linkType: hard +"@rocket.chat/emitter@npm:next": + version: 0.31.22-dev.19 + resolution: "@rocket.chat/emitter@npm:0.31.22-dev.19" + checksum: 14f8143d158545b8a6807566d89ab03edc74c077f0dec5e273e8dd6ed4ad9b865439174f2ea243f217e97e911357298096ac71d41957bd5db995e2fbafd1f849 + languageName: node + linkType: hard + "@rocket.chat/eslint-config@npm:^0.4.0": version: 0.4.0 resolution: "@rocket.chat/eslint-config@npm:0.4.0" @@ -5626,7 +6033,7 @@ __metadata: "@types/prettier": ^2.6.3 "@typescript-eslint/eslint-plugin": ^5.30.7 "@typescript-eslint/parser": ^5.30.7 - eslint: ^8.20.0 + eslint: ^8.22.0 eslint-config-prettier: ^8.5.0 eslint-plugin-anti-trojan-source: ^1.1.0 eslint-plugin-import: ^2.26.0 @@ -5640,7 +6047,7 @@ __metadata: version: 0.0.0-use.local resolution: "@rocket.chat/favicon@workspace:packages/favicon" dependencies: - eslint: ^8.20.0 + eslint: ^8.22.0 typescript: ~4.5.5 languageName: unknown linkType: soft @@ -5717,9 +6124,21 @@ __metadata: languageName: node linkType: hard -"@rocket.chat/fuselage-polyfills@npm:0.31.21": - version: 0.31.21 - resolution: "@rocket.chat/fuselage-polyfills@npm:0.31.21" +"@rocket.chat/fuselage-hooks@npm:next": + version: 0.32.0-dev.121 + resolution: "@rocket.chat/fuselage-hooks@npm:0.32.0-dev.121" + dependencies: + use-sync-external-store: ~1.2.0 + peerDependencies: + "@rocket.chat/fuselage-tokens": "*" + react: ^17.0.2 + checksum: 204ef2918876b12cd5a607c10d5ec5f8345fe28e2c9ad23fe79af681b0c79ac4fed86e49d18a1c0cb6f90b6e0b9d773f11a16ddc1801aa5479cdf8fb9de06185 + languageName: node + linkType: hard + +"@rocket.chat/fuselage-polyfills@npm:next": + version: 0.31.22-dev.19 + resolution: "@rocket.chat/fuselage-polyfills@npm:0.31.22-dev.19" dependencies: "@juggle/resize-observer": ^3.4.0 clipboard-polyfill: ^3.0.3 @@ -5727,13 +6146,13 @@ __metadata: focus-visible: ^5.2.0 focus-within-polyfill: ^5.2.1 new-event-polyfill: ^1.0.1 - checksum: 7bcb8b0e62a6755b3e35335dee47b432cebdc15480880c8cd36cf5159571fed9235b5dbc42c41492787586a5356313e2ca3a0a3866849e5a30e5acabe7d9fbbe + checksum: 8349980b707e0d243f0ebe813cfa6b33d7b87c4076b81d29efbed38a9d81526cd5104bfdedf4f1f81fc7d35943f6354a0c6e5c4b14146e87d68545c486cc6c14 languageName: node linkType: hard -"@rocket.chat/fuselage-toastbar@npm:0.31.21": - version: 0.31.21 - resolution: "@rocket.chat/fuselage-toastbar@npm:0.31.21" +"@rocket.chat/fuselage-toastbar@npm:next": + version: 0.32.0-dev.182 + resolution: "@rocket.chat/fuselage-toastbar@npm:0.32.0-dev.182" peerDependencies: "@rocket.chat/fuselage": "*" "@rocket.chat/fuselage-hooks": "*" @@ -5741,7 +6160,7 @@ __metadata: "@rocket.chat/styled": "*" react: ^17.0.2 react-dom: ^17.0.2 - checksum: 1547f822fd2acf1431cd7282d0f447e55907523a6a31f354e83ba4edb2372a27b394565eedcd35e1ba17612bebaba665f86bd08004f8bdfe95942a0b41622c6c + checksum: cede45a12788c9637f034a5fbcc3b33455e66a39f0c9f041fe51b0c157223eb18debc5435531083d7b2ec86a7f5d63ba32b3d95f44cc889d12a4a04c9358e206 languageName: node linkType: hard @@ -5752,44 +6171,28 @@ __metadata: languageName: node linkType: hard -"@rocket.chat/fuselage-tokens@npm:~0.32.0-dev.158": +"@rocket.chat/fuselage-tokens@npm:next, @rocket.chat/fuselage-tokens@npm:~0.32.0-dev.158": version: 0.32.0-dev.158 resolution: "@rocket.chat/fuselage-tokens@npm:0.32.0-dev.158" checksum: 18db2ad59b2e118161ea9835c8d1c1bfea6e8c654024c67140c4dd5a3eb6b51a6c7ee29203f22df368e1955e32fc67604f9a22193b31eb808c1c71bb9e1624f6 languageName: node linkType: hard -"@rocket.chat/fuselage-ui-kit@npm:0.31.21": - version: 0.31.21 - resolution: "@rocket.chat/fuselage-ui-kit@npm:0.31.21" - dependencies: - "@rocket.chat/ui-kit": ^0.31.21 - tslib: ^2.3.1 - peerDependencies: - "@rocket.chat/fuselage": "*" - "@rocket.chat/fuselage-hooks": "*" - "@rocket.chat/fuselage-polyfills": "*" - "@rocket.chat/icons": "*" - "@rocket.chat/styled": "*" - react: ^17.0.2 - react-dom: ^17.0.2 - checksum: 67a67b6b441b23c19e3ba935ce1ea962f98e7b16d9fd7ae4012168738994eb516702051f9937fa7129a02ca7ff630f0e6ee27c4e4d5db250e377677380b51071 - languageName: node - linkType: hard - -"@rocket.chat/fuselage-ui-kit@workspace:packages/fuselage-ui-kit": +"@rocket.chat/fuselage-ui-kit@workspace:^, @rocket.chat/fuselage-ui-kit@workspace:packages/fuselage-ui-kit": version: 0.0.0-use.local resolution: "@rocket.chat/fuselage-ui-kit@workspace:packages/fuselage-ui-kit" dependencies: "@rocket.chat/apps-engine": ~1.30.0 "@rocket.chat/eslint-config": "workspace:^" "@rocket.chat/fuselage": next - "@rocket.chat/fuselage-hooks": 0.31.21 - "@rocket.chat/fuselage-polyfills": 0.31.21 - "@rocket.chat/icons": 0.31.21 + "@rocket.chat/fuselage-hooks": next + "@rocket.chat/fuselage-polyfills": next + "@rocket.chat/icons": next "@rocket.chat/prettier-config": next - "@rocket.chat/styled": 0.31.21 - "@rocket.chat/ui-kit": 0.31.21 + "@rocket.chat/styled": next + "@rocket.chat/ui-contexts": "workspace:^" + "@rocket.chat/ui-kit": next + "@rocket.chat/ui-video-conf": "workspace:^" "@storybook/addon-essentials": ~6.5.10 "@storybook/addons": ~6.5.10 "@storybook/builder-webpack5": ~6.5.10 @@ -5797,29 +6200,36 @@ __metadata: "@storybook/react": ~6.5.10 "@storybook/source-loader": ~6.5.10 "@storybook/theming": ~6.5.10 - "@types/react": ~17.0.39 - "@types/react-dom": ^17.0.11 + "@tanstack/react-query": ^4.16.1 + "@types/react": ~17.0.48 + "@types/react-dom": ~17.0.17 babel-loader: ~8.2.3 cross-env: ^7.0.3 - eslint: ~8.8.0 + eslint: ~8.22.0 lint-staged: ~12.3.3 normalize.css: ^8.0.1 npm-run-all: ^4.1.5 prettier: ~2.5.1 - react: ^17.0.2 react-dom: ^17.0.2 rimraf: ^3.0.2 tslib: ^2.3.1 typescript: ~4.3.5 webpack: ~5.68.0 peerDependencies: + "@rocket.chat/apps-engine": "*" + "@rocket.chat/eslint-config": "*" "@rocket.chat/fuselage": "*" "@rocket.chat/fuselage-hooks": "*" "@rocket.chat/fuselage-polyfills": "*" "@rocket.chat/icons": "*" + "@rocket.chat/prettier-config": "*" "@rocket.chat/styled": "*" - react: ^17.0.2 - react-dom: ^17.0.2 + "@rocket.chat/ui-contexts": "*" + "@rocket.chat/ui-kit": "*" + "@rocket.chat/ui-video-conf": "*" + "@tanstack/react-query": "*" + react: "*" + react-dom: "*" languageName: unknown linkType: soft @@ -5851,7 +6261,7 @@ __metadata: version: 0.0.0-use.local resolution: "@rocket.chat/gazzodown@workspace:packages/gazzodown" dependencies: - "@babel/core": ^7.18.9 + "@babel/core": ~7.18.13 "@mdx-js/react": ^1.6.22 "@rocket.chat/core-typings": "workspace:^" "@rocket.chat/css-in-js": 0.31.21 @@ -5875,13 +6285,13 @@ __metadata: "@types/babel__core": ^7 "@types/jest": ^27.4.1 "@types/katex": ~0 - "@types/react": ^17.0.47 - "@types/react-dom": ^18 + "@types/react": ~17.0.48 + "@types/react-dom": ~17.0.17 "@types/testing-library__jest-dom": ^5 "@typescript-eslint/eslint-plugin": ^5.30.7 "@typescript-eslint/parser": ^5.30.7 babel-loader: ^8.2.5 - eslint: ^8.20.0 + eslint: ^8.22.0 eslint-plugin-anti-trojan-source: ^1.1.0 eslint-plugin-react: ^7.30.1 eslint-plugin-react-hooks: ^4.6.0 @@ -5895,16 +6305,16 @@ __metadata: ts-jest: ^27.1.4 typescript: ~4.5.5 peerDependencies: - "@rocket.chat/core-typings": "workspace:^" + "@rocket.chat/core-typings": "*" "@rocket.chat/css-in-js": "*" "@rocket.chat/fuselage": "*" "@rocket.chat/fuselage-tokens": "*" "@rocket.chat/message-parser": "*" "@rocket.chat/styled": "*" - "@rocket.chat/ui-client": "workspace:^" - "@rocket.chat/ui-contexts": "workspace:^" + "@rocket.chat/ui-client": "*" + "@rocket.chat/ui-contexts": "*" katex: "*" - react: ~17.0.2 + react: "*" languageName: unknown linkType: soft @@ -5915,6 +6325,13 @@ __metadata: languageName: node linkType: hard +"@rocket.chat/icons@npm:next": + version: 0.32.0-dev.190 + resolution: "@rocket.chat/icons@npm:0.32.0-dev.190" + checksum: cd4003711336f4934821a20308a1c038c4f6eba0c701c8a7439430b53dab6bb829ec4d6e44943a43ed903ba13cdde0f2f35f9f92d3d8c0adaba8a6abb8968462 + languageName: node + linkType: hard + "@rocket.chat/layout@npm:next": version: 0.32.0-dev.57 resolution: "@rocket.chat/layout@npm:0.32.0-dev.57" @@ -5932,7 +6349,7 @@ __metadata: resolution: "@rocket.chat/livechat@workspace:packages/livechat" dependencies: "@babel/eslint-parser": ^7.18.9 - "@babel/preset-env": ^7.18.9 + "@babel/preset-env": ^7.18.10 "@rocket.chat/eslint-config": ^0.4.0 "@rocket.chat/fuselage-tokens": 0.31.21 "@rocket.chat/logo": 0.31.21 @@ -5946,7 +6363,6 @@ __metadata: "@storybook/addon-viewport": ~6.5.10 "@storybook/react": ~6.5.10 "@storybook/theming": ~6.5.10 - "@types/react-dom": ^17.0.17 autoprefixer: ^9.8.8 babel-loader: ^8.1.0 babel-plugin-jsx-pragmatic: ^1.0.2 @@ -5958,7 +6374,7 @@ __metadata: date-fns: ^2.15.0 desvg-loader: ^0.1.0 emoji-mart: ^3.0.1 - eslint: ^8.20.0 + eslint: ^8.22.0 eslint-plugin-import: ^2.26.0 eslint-plugin-react: ^7.30.1 eslint-plugin-react-hooks: ^4.6.0 @@ -6048,11 +6464,11 @@ __metadata: version: 0.0.0-use.local resolution: "@rocket.chat/meteor@workspace:apps/meteor" dependencies: - "@babel/core": ^7.18.9 + "@babel/core": ^7.18.13 "@babel/eslint-parser": ^7.18.9 "@babel/plugin-proposal-nullish-coalescing-operator": ^7.18.6 "@babel/plugin-proposal-optional-chaining": ^7.18.9 - "@babel/preset-env": ^7.18.9 + "@babel/preset-env": ^7.18.10 "@babel/preset-react": ^7.18.6 "@babel/register": ^7.18.9 "@babel/runtime": ^7.18.9 @@ -6069,7 +6485,7 @@ __metadata: "@react-aria/color": ^3.0.0-beta.15 "@rocket.chat/agenda": "workspace:^" "@rocket.chat/api-client": "workspace:^" - "@rocket.chat/apps-engine": latest + "@rocket.chat/apps-engine": 1.36.0-videoconf "@rocket.chat/cas-validate": "workspace:^" "@rocket.chat/core-typings": "workspace:^" "@rocket.chat/css-in-js": 0.31.21 @@ -6079,11 +6495,11 @@ __metadata: "@rocket.chat/forked-matrix-appservice-bridge": ^4.0.1 "@rocket.chat/forked-matrix-bot-sdk": ^0.6.0-beta.2 "@rocket.chat/fuselage": next - "@rocket.chat/fuselage-hooks": 0.31.21 - "@rocket.chat/fuselage-polyfills": 0.31.21 - "@rocket.chat/fuselage-toastbar": 0.31.21 - "@rocket.chat/fuselage-tokens": 0.31.21 - "@rocket.chat/fuselage-ui-kit": 0.31.21 + "@rocket.chat/fuselage-hooks": next + "@rocket.chat/fuselage-polyfills": next + "@rocket.chat/fuselage-toastbar": next + "@rocket.chat/fuselage-tokens": next + "@rocket.chat/fuselage-ui-kit": "workspace:^" "@rocket.chat/gazzodown": "workspace:^" "@rocket.chat/icons": 0.31.21 "@rocket.chat/layout": next @@ -6114,7 +6530,7 @@ __metadata: "@storybook/addons": ~6.5.10 "@storybook/react": ~6.5.10 "@storybook/testing-library": 0.0.13 - "@tanstack/react-query": ^4.0.10 + "@tanstack/react-query": ^4.16.1 "@testing-library/react": ~12.1.5 "@testing-library/react-hooks": ^8.0.1 "@testing-library/user-event": ~13.5.0 @@ -6169,7 +6585,7 @@ __metadata: "@types/proxy-from-env": ^1.0.1 "@types/proxyquire": ^1.3.28 "@types/psl": ^1.1.0 - "@types/react": ~17.0.47 + "@types/react": ~17.0.48 "@types/react-dom": ~17.0.17 "@types/rewire": ^2.5.28 "@types/sanitize-html": ^2 @@ -6233,7 +6649,7 @@ __metadata: emailreplyparser: ^0.0.5 emojione: ^4.5.0 emojione-assets: ^4.5.0 - eslint: ^8.20.0 + eslint: ^8.22.0 eslint-config-prettier: ^8.5.0 eslint-plugin-anti-trojan-source: ^1.1.0 eslint-plugin-import: ^2.26.0 @@ -6387,7 +6803,7 @@ __metadata: "@rocket.chat/core-typings": "workspace:^" "@types/jest": ^27.4.1 "@types/node-rsa": ^1.1.1 - eslint: ^8.20.0 + eslint: ^8.22.0 jest: ^27.5.1 mongodb: ^4.3.1 ts-jest: ^27.1.5 @@ -6401,7 +6817,7 @@ __metadata: dependencies: "@rocket.chat/model-typings": "workspace:^" "@types/jest": ^27.4.1 - eslint: ^8.20.0 + eslint: ^8.22.0 jest: ^27.5.1 ts-jest: ^27.1.5 typescript: ~4.5.5 @@ -6444,7 +6860,7 @@ __metadata: resolution: "@rocket.chat/poplib@workspace:packages/node-poplib" dependencies: "@types/jest": ^27.4.1 - eslint: ^8.20.0 + eslint: ^8.22.0 jest: ^27.5.1 ts-jest: ^27.1.4 typescript: ~4.5.5 @@ -6520,7 +6936,7 @@ __metadata: "@rocket.chat/ui-kit": 0.31.21 "@types/jest": ^27.4.1 ajv: ^8.11.0 - eslint: ^8.20.0 + eslint: ^8.22.0 jest: ^27.5.1 mongodb: ^4.3.1 ts-jest: ^27.1.5 @@ -6590,7 +7006,7 @@ __metadata: languageName: node linkType: hard -"@rocket.chat/styled@npm:~0.31.22-dev.19": +"@rocket.chat/styled@npm:next, @rocket.chat/styled@npm:~0.31.22-dev.19": version: 0.31.22-dev.19 resolution: "@rocket.chat/styled@npm:0.31.22-dev.19" dependencies: @@ -6628,10 +7044,11 @@ __metadata: version: 0.0.0-use.local resolution: "@rocket.chat/ui-client@workspace:packages/ui-client" dependencies: - "@rocket.chat/css-in-js": 0.31.21 + "@babel/core": ~7.18.13 + "@rocket.chat/css-in-js": next "@rocket.chat/fuselage": next - "@rocket.chat/fuselage-hooks": 0.31.21 - "@rocket.chat/icons": 0.31.21 + "@rocket.chat/fuselage-hooks": next + "@rocket.chat/icons": next "@rocket.chat/ui-contexts": "workspace:~" "@storybook/addon-actions": ~6.5.10 "@storybook/addon-docs": ~6.5.10 @@ -6643,10 +7060,12 @@ __metadata: "@storybook/manager-webpack4": ~6.5.10 "@storybook/react": ~6.5.10 "@storybook/testing-library": ~0.0.13 + "@types/babel__core": ^7 "@types/jest": ^27.4.1 "@types/postcss-url": ^10 - "@types/react": ~17.0.47 - eslint: ^8.20.0 + "@types/react": ~17.0.48 + "@types/react-dom": ~17.0.17 + eslint: ^8.22.0 eslint-plugin-anti-trojan-source: ^1.1.0 eslint-plugin-react: ^7.30.1 eslint-plugin-react-hooks: ^4.6.0 @@ -6667,6 +7086,7 @@ __metadata: "@rocket.chat/fuselage": "*" "@rocket.chat/fuselage-hooks": "*" "@rocket.chat/icons": "*" + "@rocket.chat/ui-contexts": "*" react: ~17.0.2 languageName: unknown linkType: soft @@ -6712,9 +7132,10 @@ __metadata: "@rocket.chat/fuselage-hooks": 0.31.21 "@rocket.chat/rest-typings": "workspace:^" "@types/jest": ^27.4.1 - "@types/react": ^17.0.47 + "@types/react": ~17.0.48 + "@types/react-dom": ~17.0.17 "@types/use-sync-external-store": ^0.0.3 - eslint: ^8.20.0 + eslint: ^8.22.0 jest: ^27.5.1 mongodb: ^4.3.1 react: ~17.0.2 @@ -6731,13 +7152,20 @@ __metadata: languageName: unknown linkType: soft -"@rocket.chat/ui-kit@npm:0.31.21, @rocket.chat/ui-kit@npm:^0.31.21": +"@rocket.chat/ui-kit@npm:0.31.21": version: 0.31.21 resolution: "@rocket.chat/ui-kit@npm:0.31.21" checksum: 05dadff647d75ae586217b36838b6b5dbc93b4d5dfa2c967306a4ccb238b9815d58d365ac9d4cc9d2ae5a6a46007285e8fd7781d118c59152319eb2a37b2f8eb languageName: node linkType: hard +"@rocket.chat/ui-kit@npm:next": + version: 0.32.0-dev.143 + resolution: "@rocket.chat/ui-kit@npm:0.32.0-dev.143" + checksum: 65077dd083e5abc2c115becc5823686f2f49c6810f3b874aa55b680d5e8f591aace502073ceaf89051c1da2f5b8122552a782acec92b8d233900737581fbbd33 + languageName: node + linkType: hard + "@rocket.chat/ui-theming@workspace:^, @rocket.chat/ui-theming@workspace:ee/packages/ui-theming": version: 0.0.0-use.local resolution: "@rocket.chat/ui-theming@workspace:ee/packages/ui-theming" @@ -6789,15 +7217,28 @@ __metadata: version: 0.0.0-use.local resolution: "@rocket.chat/ui-video-conf@workspace:packages/ui-video-conf" dependencies: - "@rocket.chat/css-in-js": 0.31.21 + "@babel/core": ~7.18.13 + "@rocket.chat/css-in-js": next + "@rocket.chat/emitter": next "@rocket.chat/eslint-config": "workspace:^" "@rocket.chat/fuselage": next - "@rocket.chat/fuselage-hooks": 0.31.21 - "@rocket.chat/styled": 0.31.21 + "@rocket.chat/fuselage-hooks": next + "@rocket.chat/icons": next + "@rocket.chat/styled": next + "@rocket.chat/ui-contexts": "workspace:^" + "@storybook/addon-actions": ~6.5.10 + "@storybook/addon-docs": ~6.5.10 + "@storybook/addon-essentials": ~6.5.10 + "@storybook/builder-webpack4": ~6.5.10 + "@storybook/manager-webpack4": ~6.5.10 + "@storybook/react": ~6.5.10 + "@storybook/testing-library": ~0.0.13 + "@types/babel__core": ^7 "@types/jest": ^27.4.1 - eslint: ^8.20.0 + eslint: ^8.22.0 eslint-plugin-react: ^7.30.1 eslint-plugin-react-hooks: ^4.6.0 + eslint-plugin-storybook: ^0.6.4 jest: ^27.5.1 ts-jest: ^27.1.4 typescript: ~4.5.5 @@ -6805,7 +7246,9 @@ __metadata: "@rocket.chat/css-in-js": "*" "@rocket.chat/fuselage": "*" "@rocket.chat/fuselage-hooks": "*" + "@rocket.chat/icons": "*" "@rocket.chat/styled": "*" + "@rocket.chat/ui-contexts": "*" react: ^17.0.2 react-dom: ^17.0.2 languageName: unknown @@ -6817,7 +7260,7 @@ __metadata: dependencies: "@rocket.chat/layout": next "@rocket.chat/ui-contexts": "workspace:^" - "@tanstack/react-query": ^4.2.3 + "@tanstack/react-query": ^4.16.1 "@testing-library/react": ^13.3.0 "@types/jest": ^27.4.1 eslint: ^8.12.0 @@ -8681,19 +9124,18 @@ __metadata: languageName: node linkType: hard -"@tanstack/query-core@npm:4.2.3": - version: 4.2.3 - resolution: "@tanstack/query-core@npm:4.2.3" - checksum: b37efdc32b1731575eba398eda3b7a4cd3ed25ee1032d5200124c37ab4e58711d310e2e29e9e51284553a7c03c85e55cf8da6833bc3b1e215e0e43e7399ab3ca +"@tanstack/query-core@npm:4.15.1": + version: 4.15.1 + resolution: "@tanstack/query-core@npm:4.15.1" + checksum: ee98e75a3770fd35a6a10b9e7b3c417ea9da2b072481b5191d759182b29fd7bc4e8e340f83e2961b46fe4e1adac356087df04d4661c9459d09ff4d0574f683eb languageName: node linkType: hard -"@tanstack/react-query@npm:^4.0.10, @tanstack/react-query@npm:^4.2.3": - version: 4.2.3 - resolution: "@tanstack/react-query@npm:4.2.3" +"@tanstack/react-query@npm:^4.16.1": + version: 4.16.1 + resolution: "@tanstack/react-query@npm:4.16.1" dependencies: - "@tanstack/query-core": 4.2.3 - "@types/use-sync-external-store": ^0.0.3 + "@tanstack/query-core": 4.15.1 use-sync-external-store: ^1.2.0 peerDependencies: react: ^16.8.0 || ^17.0.0 || ^18.0.0 @@ -8704,7 +9146,7 @@ __metadata: optional: true react-native: optional: true - checksum: 0a38ae05271e1669c6efd5cc77608103b6dfde577ecdc88c3f0e72953aea11c102c9b5a49fa2ca822f260a68f9f9646c5e847e7d87c99117b2c2e3b1356cbc8b + checksum: 2c2d4c5c8bab2cd978ddd42153d33f844bd24a17ebe42f269cc64ee2a031f60f980b441640172885d9fd156fe9abc74ffc800fb68c6b6f6ef4fe48ffadafff79 languageName: node linkType: hard @@ -9730,7 +10172,7 @@ __metadata: languageName: node linkType: hard -"@types/react-dom@npm:<18.0.0, @types/react-dom@npm:^17.0.11, @types/react-dom@npm:^17.0.17, @types/react-dom@npm:~17.0.17": +"@types/react-dom@npm:<18.0.0, @types/react-dom@npm:~17.0.17": version: 17.0.17 resolution: "@types/react-dom@npm:17.0.17" dependencies: @@ -9739,7 +10181,7 @@ __metadata: languageName: node linkType: hard -"@types/react-dom@npm:^18, @types/react-dom@npm:^18.0.0": +"@types/react-dom@npm:^18.0.0": version: 18.0.6 resolution: "@types/react-dom@npm:18.0.6" dependencies: @@ -9759,7 +10201,7 @@ __metadata: languageName: node linkType: hard -"@types/react@npm:^17.0.47, @types/react@npm:~17.0.39, @types/react@npm:~17.0.47": +"@types/react@npm:~17.0.47": version: 17.0.50 resolution: "@types/react@npm:17.0.50" dependencies: @@ -9770,6 +10212,17 @@ __metadata: languageName: node linkType: hard +"@types/react@npm:~17.0.48": + version: 17.0.52 + resolution: "@types/react@npm:17.0.52" + dependencies: + "@types/prop-types": "*" + "@types/scheduler": "*" + csstype: ^3.0.2 + checksum: a51b98dd87838d161278fdf9dd78e6a4ff8c018f406d6647f77963e144fb52a8beee40c89fd0e7e840eaeaa8bd9fe2f34519410540b1a52d43a6f8b4d2fbce33 + languageName: node + linkType: hard + "@types/responselike@npm:^1.0.0": version: 1.0.0 resolution: "@types/responselike@npm:1.0.0" @@ -16938,7 +17391,7 @@ __metadata: languageName: node linkType: hard -"eslint-scope@npm:^7.1.0, eslint-scope@npm:^7.1.1": +"eslint-scope@npm:^7.1.1": version: 7.1.1 resolution: "eslint-scope@npm:7.1.1" dependencies: @@ -16982,7 +17435,7 @@ __metadata: languageName: node linkType: hard -"eslint-visitor-keys@npm:^3.2.0, eslint-visitor-keys@npm:^3.3.0": +"eslint-visitor-keys@npm:^3.3.0": version: 3.3.0 resolution: "eslint-visitor-keys@npm:3.3.0" checksum: d59e68a7c5a6d0146526b0eec16ce87fbf97fe46b8281e0d41384224375c4e52f5ffb9e16d48f4ea50785cde93f766b0c898e31ab89978d88b0e1720fbfb7808 @@ -17186,29 +17639,33 @@ __metadata: languageName: node linkType: hard -"eslint@npm:~8.8.0": - version: 8.8.0 - resolution: "eslint@npm:8.8.0" +"eslint@npm:~8.22.0": + version: 8.22.0 + resolution: "eslint@npm:8.22.0" dependencies: - "@eslint/eslintrc": ^1.0.5 - "@humanwhocodes/config-array": ^0.9.2 + "@eslint/eslintrc": ^1.3.0 + "@humanwhocodes/config-array": ^0.10.4 + "@humanwhocodes/gitignore-to-minimatch": ^1.0.2 ajv: ^6.10.0 chalk: ^4.0.0 cross-spawn: ^7.0.2 debug: ^4.3.2 doctrine: ^3.0.0 escape-string-regexp: ^4.0.0 - eslint-scope: ^7.1.0 + eslint-scope: ^7.1.1 eslint-utils: ^3.0.0 - eslint-visitor-keys: ^3.2.0 - espree: ^9.3.0 + eslint-visitor-keys: ^3.3.0 + espree: ^9.3.3 esquery: ^1.4.0 esutils: ^2.0.2 fast-deep-equal: ^3.1.3 file-entry-cache: ^6.0.1 + find-up: ^5.0.0 functional-red-black-tree: ^1.0.1 glob-parent: ^6.0.1 - globals: ^13.6.0 + globals: ^13.15.0 + globby: ^11.1.0 + grapheme-splitter: ^1.0.4 ignore: ^5.2.0 import-fresh: ^3.0.0 imurmurhash: ^0.1.4 @@ -17217,7 +17674,7 @@ __metadata: json-stable-stringify-without-jsonify: ^1.0.1 levn: ^0.4.1 lodash.merge: ^4.6.2 - minimatch: ^3.0.4 + minimatch: ^3.1.2 natural-compare: ^1.4.0 optionator: ^0.9.1 regexpp: ^3.2.0 @@ -17227,7 +17684,7 @@ __metadata: v8-compile-cache: ^2.0.3 bin: eslint: bin/eslint.js - checksum: 41a7e85bf84cf9f2d758ef3e8d08020a39a2836703728b59535684681349bd021c2c6e24174462b844a914870d707d2151e0371198899d957b444de91adaa435 + checksum: 2d84a7a2207138cdb250759b047fdb05a57fede7f87b7a039d9370edba7f26e23a873a208becfd4b2c9e4b5499029f3fc3b9318da3290e693d25c39084119c80 languageName: node linkType: hard @@ -17242,7 +17699,18 @@ __metadata: languageName: node linkType: hard -"espree@npm:^9.3.0, espree@npm:^9.4.0": +"espree@npm:^9.3.3": + version: 9.4.1 + resolution: "espree@npm:9.4.1" + dependencies: + acorn: ^8.8.0 + acorn-jsx: ^5.3.2 + eslint-visitor-keys: ^3.3.0 + checksum: 4d266b0cf81c7dfe69e542c7df0f246e78d29f5b04dda36e514eb4c7af117ee6cfbd3280e560571ed82ff6c9c3f0003c05b82583fc7a94006db7497c4fe4270e + languageName: node + linkType: hard + +"espree@npm:^9.4.0": version: 9.4.0 resolution: "espree@npm:9.4.0" dependencies: @@ -30120,7 +30588,7 @@ __metadata: languageName: node linkType: hard -"react@npm:^17.0.2, react@npm:~17.0.2": +"react@npm:~17.0.2": version: 17.0.2 resolution: "react@npm:17.0.2" dependencies: